mirror of https://gitlab.crans.org/bde/nk20
Merge branch 'traduction_inclusive_fr' into 'beta'
De l'inclusif, partout See merge request bde/nk20!258
This commit is contained in:
commit
47138bafd4
|
@ -1,3 +1,3 @@
|
||||||
[submodule "apps/scripts"]
|
[submodule "apps/scripts"]
|
||||||
path = apps/scripts
|
path = apps/scripts
|
||||||
url = https://gitlab.crans.org/bde/nk20-scripts.git
|
url = https://gitlab.crans.org/bde/nk20-scripts
|
||||||
|
|
|
@ -55,7 +55,7 @@ Bien que cela permette de créer une instance sur toutes les distributions,
|
||||||
(env)$ ./manage.py makemigrations
|
(env)$ ./manage.py makemigrations
|
||||||
(env)$ ./manage.py migrate
|
(env)$ ./manage.py migrate
|
||||||
(env)$ ./manage.py loaddata initial
|
(env)$ ./manage.py loaddata initial
|
||||||
(env)$ ./manage.py createsuperuser # Création d'un utilisateur initial
|
(env)$ ./manage.py createsuperuser # Création d'un⋅e utilisateur⋅rice initial
|
||||||
```
|
```
|
||||||
|
|
||||||
6. Enjoy :
|
6. Enjoy :
|
||||||
|
|
|
@ -56,13 +56,13 @@ def save_object(sender, instance, **kwargs):
|
||||||
# noinspection PyProtectedMember
|
# noinspection PyProtectedMember
|
||||||
previous = instance._previous
|
previous = instance._previous
|
||||||
|
|
||||||
# Si un utilisateur est connecté, on récupère l'utilisateur courant ainsi que son adresse IP
|
# Si un⋅e utilisateur⋅rice est connecté⋅e, on récupère l'utilisateur⋅rice courant⋅e ainsi que son adresse IP
|
||||||
request = get_current_request()
|
request = get_current_request()
|
||||||
|
|
||||||
if request is None:
|
if request is None:
|
||||||
# Si la modification n'a pas été faite via le client Web, on suppose que c'est du à `manage.py`
|
# Si la modification n'a pas été faite via le client Web, on suppose que c'est du à `manage.py`
|
||||||
# On récupère alors l'utilisateur·trice connecté·e à la VM, et on récupère la note associée
|
# On récupère alors l'utilisateur·trice connecté·e à la VM, et on récupère la note associée
|
||||||
# IMPORTANT : l'utilisateur dans la VM doit être un des alias note du respo info
|
# IMPORTANT : l'utilisateur⋅rice dans la VM doit être un des alias note du respo info
|
||||||
ip = "127.0.0.1"
|
ip = "127.0.0.1"
|
||||||
username = Alias.normalize(getpass.getuser())
|
username = Alias.normalize(getpass.getuser())
|
||||||
note = NoteUser.objects.filter(alias__normalized_name=username)
|
note = NoteUser.objects.filter(alias__normalized_name=username)
|
||||||
|
@ -134,13 +134,13 @@ def delete_object(sender, instance, **kwargs):
|
||||||
if instance._meta.label_lower in EXCLUDED or hasattr(instance, "_no_signal"):
|
if instance._meta.label_lower in EXCLUDED or hasattr(instance, "_no_signal"):
|
||||||
return
|
return
|
||||||
|
|
||||||
# Si un utilisateur est connecté, on récupère l'utilisateur courant ainsi que son adresse IP
|
# Si un⋅e utilisateur⋅rice est connecté⋅e, on récupère l'utilisateur⋅rice courant⋅e ainsi que son adresse IP
|
||||||
request = get_current_request()
|
request = get_current_request()
|
||||||
|
|
||||||
if request is None:
|
if request is None:
|
||||||
# Si la modification n'a pas été faite via le client Web, on suppose que c'est du à `manage.py`
|
# Si la modification n'a pas été faite via le client Web, on suppose que c'est du à `manage.py`
|
||||||
# On récupère alors l'utilisateur·trice connecté·e à la VM, et on récupère la note associée
|
# On récupère alors l'utilisateur·trice connecté·e à la VM, et on récupère la note associée
|
||||||
# IMPORTANT : l'utilisateur dans la VM doit être un des alias note du respo info
|
# IMPORTANT : l'utilisateur⋅rice dans la VM doit être un des alias note du respo info
|
||||||
ip = "127.0.0.1"
|
ip = "127.0.0.1"
|
||||||
username = Alias.normalize(getpass.getuser())
|
username = Alias.normalize(getpass.getuser())
|
||||||
note = NoteUser.objects.filter(alias__normalized_name=username)
|
note = NoteUser.objects.filter(alias__normalized_name=username)
|
||||||
|
|
|
@ -210,9 +210,9 @@ class MembershipForm(forms.ModelForm):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Membership
|
model = Membership
|
||||||
fields = ('user', 'date_start')
|
fields = ('user', 'date_start')
|
||||||
# Le champ d'utilisateur est remplacé par un champ d'auto-complétion.
|
# Le champ d'utilisateur⋅rice est remplacé par un champ d'auto-complétion.
|
||||||
# Quand des lettres sont tapées, une requête est envoyée sur l'API d'auto-complétion
|
# Quand des lettres sont tapées, une requête est envoyée sur l'API d'auto-complétion
|
||||||
# et récupère les noms d'utilisateur valides
|
# et récupère les noms d'utilisateur⋅rices valides
|
||||||
widgets = {
|
widgets = {
|
||||||
'user':
|
'user':
|
||||||
Autocomplete(
|
Autocomplete(
|
||||||
|
|
|
@ -473,10 +473,10 @@ class Membership(models.Model):
|
||||||
|
|
||||||
if self.club.parent_club.name == "BDE":
|
if self.club.parent_club.name == "BDE":
|
||||||
parent_membership.roles.set(
|
parent_membership.roles.set(
|
||||||
Role.objects.filter(Q(name="Adhérent BDE") | Q(name="Membre de club")).all())
|
Role.objects.filter(Q(name="Adhérent⋅e BDE") | Q(name="Membre de club")).all())
|
||||||
elif self.club.parent_club.name == "Kfet":
|
elif self.club.parent_club.name == "Kfet":
|
||||||
parent_membership.roles.set(
|
parent_membership.roles.set(
|
||||||
Role.objects.filter(Q(name="Adhérent Kfet") | Q(name="Membre de club")).all())
|
Role.objects.filter(Q(name="Adhérent⋅e Kfet") | Q(name="Membre de club")).all())
|
||||||
else:
|
else:
|
||||||
parent_membership.roles.set(Role.objects.filter(name="Membre de club").all())
|
parent_membership.roles.set(Role.objects.filter(name="Membre de club").all())
|
||||||
parent_membership.save()
|
parent_membership.save()
|
||||||
|
|
|
@ -291,7 +291,7 @@ class TestMemberships(TestCase):
|
||||||
|
|
||||||
response = self.client.post(reverse("member:club_manage_roles", args=(self.membership.pk,)), data=dict(
|
response = self.client.post(reverse("member:club_manage_roles", args=(self.membership.pk,)), data=dict(
|
||||||
roles=[role.id for role in Role.objects.filter(
|
roles=[role.id for role in Role.objects.filter(
|
||||||
Q(name="Membre de club") | Q(name="Trésorier·ère de club") | Q(name="Bureau de club")).all()],
|
Q(name="Membre de club") | Q(name="Trésorièr⋅e de club") | Q(name="Bureau de club")).all()],
|
||||||
))
|
))
|
||||||
self.assertRedirects(response, self.user.profile.get_absolute_url(), 302, 200)
|
self.assertRedirects(response, self.user.profile.get_absolute_url(), 302, 200)
|
||||||
self.membership.refresh_from_db()
|
self.membership.refresh_from_db()
|
||||||
|
|
|
@ -827,8 +827,8 @@ class ClubAddMemberView(ProtectQuerysetMixin, ProtectedCreateView):
|
||||||
|
|
||||||
ret = super().form_valid(form)
|
ret = super().form_valid(form)
|
||||||
|
|
||||||
member_role = Role.objects.filter(Q(name="Adhérent BDE") | Q(name="Membre de club")).all() \
|
member_role = Role.objects.filter(Q(name="Adhérent⋅e BDE") | Q(name="Membre de club")).all() \
|
||||||
if club.name == "BDE" else Role.objects.filter(Q(name="Adhérent Kfet") | Q(name="Membre de club")).all() \
|
if club.name == "BDE" else Role.objects.filter(Q(name="Adhérent⋅e Kfet") | Q(name="Membre de club")).all() \
|
||||||
if club.name == "Kfet"else Role.objects.filter(name="Membre de club").all()
|
if club.name == "Kfet"else Role.objects.filter(name="Membre de club").all()
|
||||||
# Set the same roles as before
|
# Set the same roles as before
|
||||||
if old_membership:
|
if old_membership:
|
||||||
|
@ -864,7 +864,7 @@ class ClubAddMemberView(ProtectQuerysetMixin, ProtectedCreateView):
|
||||||
membership.refresh_from_db()
|
membership.refresh_from_db()
|
||||||
if old_membership.exists():
|
if old_membership.exists():
|
||||||
membership.roles.set(old_membership.get().roles.all())
|
membership.roles.set(old_membership.get().roles.all())
|
||||||
membership.roles.set(Role.objects.filter(Q(name="Adhérent Kfet") | Q(name="Membre de club")).all())
|
membership.roles.set(Role.objects.filter(Q(name="Adhérent⋅e Kfet") | Q(name="Membre de club")).all())
|
||||||
membership.save()
|
membership.save()
|
||||||
|
|
||||||
return ret
|
return ret
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
Par ailleurs, le BDE ne sert pas d'alcool aux adhérents dont le solde
|
Par ailleurs, le BDE ne sert pas d'alcool aux adhérent⋅es dont le solde
|
||||||
est inférieur à 0 €.
|
est inférieur à 0 €.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
|
|
@ -22,4 +22,4 @@ virement bancaire.
|
||||||
--
|
--
|
||||||
Le BDE
|
Le BDE
|
||||||
|
|
||||||
{% trans "Mail generated by the Note Kfet on the" %} {% now "j F Y à H:i:s" %}
|
{% trans "Mail generated by the Note Kfet on the" %} {% now "j F Y à H:i:s" %}
|
||||||
|
|
|
@ -36,7 +36,7 @@
|
||||||
"mask": 1,
|
"mask": 1,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": true,
|
"permanent": true,
|
||||||
"description": "Voir son compte utilisateur"
|
"description": "Voir son compte utilisateur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -68,7 +68,7 @@
|
||||||
"mask": 1,
|
"mask": 1,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": true,
|
"permanent": true,
|
||||||
"description": "Voir sa propre note d'utilisateur"
|
"description": "Voir sa propre note d'utilisateur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -116,7 +116,7 @@
|
||||||
"mask": 1,
|
"mask": 1,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Voir les aliases des notes des clubs et des adhérents du club BDE"
|
"description": "Voir les alias des notes des clubs et des adhérent⋅es du club BDE"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -772,7 +772,7 @@
|
||||||
"mask": 3,
|
"mask": 3,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Voir les adhérents du club"
|
"description": "Voir les adhérent⋅es du club"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -788,7 +788,7 @@
|
||||||
"mask": 2,
|
"mask": 2,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Ajouter un membre à un club"
|
"description": "Ajouter un⋅e membre à un club"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -852,7 +852,7 @@
|
||||||
"mask": 3,
|
"mask": 3,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Modifier n'importe quel utilisateur"
|
"description": "Modifier n'importe quel⋅le utilisateur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -868,7 +868,7 @@
|
||||||
"mask": 3,
|
"mask": 3,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Ajouter un utilisateur"
|
"description": "Ajouter un⋅e utilisateur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -1284,7 +1284,7 @@
|
||||||
"mask": 2,
|
"mask": 2,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Inscrire un 1A au WEI"
|
"description": "Inscrire un⋅e 1A au WEI"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -1956,7 +1956,7 @@
|
||||||
"mask": 1,
|
"mask": 1,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": true,
|
"permanent": true,
|
||||||
"description": "Voir mes activitées passées, même après la fin de l'adhésion BDE"
|
"description": "Voir mes activités passées, même après la fin de l'adhésion BDE"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2100,7 +2100,7 @@
|
||||||
"mask": 3,
|
"mask": 3,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Voir n'importe quel utilisateur"
|
"description": "Voir n'importe quel⋅le utilisateur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2228,7 +2228,7 @@
|
||||||
"mask": 3,
|
"mask": 3,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Créer une note d'utilisateur"
|
"description": "Créer une note d'utilisateur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2276,7 +2276,7 @@
|
||||||
"mask": 3,
|
"mask": 3,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Voir tous les adhérents de tous les clubs"
|
"description": "Voir toustes les adhérent⋅es de tous les clubs"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2292,7 +2292,7 @@
|
||||||
"mask": 3,
|
"mask": 3,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Ajouter un membre à n'importe quel club"
|
"description": "Ajouter un⋅e membre à n'importe quel club"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2372,7 +2372,7 @@
|
||||||
"mask": 1,
|
"mask": 1,
|
||||||
"field": "name",
|
"field": "name",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Modifier le nom d'une activité non validée dont on est l'auteur"
|
"description": "Modifier le nom d'une activité non validée dont on est l'auteur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2388,7 +2388,7 @@
|
||||||
"mask": 1,
|
"mask": 1,
|
||||||
"field": "description",
|
"field": "description",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Modifier la description d'une activité non validée dont on est l'auteur"
|
"description": "Modifier la description d'une activité non validée dont on est l'auteur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2404,7 +2404,7 @@
|
||||||
"mask": 1,
|
"mask": 1,
|
||||||
"field": "location",
|
"field": "location",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Modifier le lieu d'une activité non validée dont on est l'auteur"
|
"description": "Modifier le lieu d'une activité non validée dont on est l'auteur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2420,7 +2420,7 @@
|
||||||
"mask": 1,
|
"mask": 1,
|
||||||
"field": "activity_type",
|
"field": "activity_type",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Modifier le type d'une activité non validée dont on est l'auteur"
|
"description": "Modifier le type d'une activité non validée dont on est l'auteur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2436,7 +2436,7 @@
|
||||||
"mask": 1,
|
"mask": 1,
|
||||||
"field": "organizer",
|
"field": "organizer",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Modifier l'organisateur d'une activité non validée dont on est l'auteur"
|
"description": "Modifier l'organisateur d'une activité non validée dont on est l'auteur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2452,7 +2452,7 @@
|
||||||
"mask": 1,
|
"mask": 1,
|
||||||
"field": "attendees_club",
|
"field": "attendees_club",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Modifier le club attendu d'une activité non validée dont on est l'auteur"
|
"description": "Modifier le club attendu d'une activité non validée dont on est l'auteur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2468,7 +2468,7 @@
|
||||||
"mask": 1,
|
"mask": 1,
|
||||||
"field": "date_start",
|
"field": "date_start",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Modifier la date de début d'une activité non validée dont on est l'auteur"
|
"description": "Modifier la date de début d'une activité non validée dont on est l'auteur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2484,7 +2484,7 @@
|
||||||
"mask": 1,
|
"mask": 1,
|
||||||
"field": "date_end",
|
"field": "date_end",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Modifier la date de fin d'une activité non validée dont on est l'auteur"
|
"description": "Modifier la date de fin d'une activité non validée dont on est l'auteur⋅rice"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2756,7 +2756,7 @@
|
||||||
"mask": 3,
|
"mask": 3,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Modifier n'importe quel utilisateur non encore inscrit"
|
"description": "Modifier n'importe quel⋅le utilisateur⋅rice non encore inscrit⋅e"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2788,7 +2788,7 @@
|
||||||
"mask": 3,
|
"mask": 3,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Voir tous les alias, y compris ceux des non adhérents"
|
"description": "Voir tous les alias, y compris ceux des non adhérent⋅es"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2820,7 +2820,7 @@
|
||||||
"mask": 2,
|
"mask": 2,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Voir n'importe quel utilisateur non encore inscrit"
|
"description": "Voir n'importe quel⋅le utilisateur⋅rice non encore inscrit⋅e"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -2847,12 +2847,12 @@
|
||||||
"auth",
|
"auth",
|
||||||
"user"
|
"user"
|
||||||
],
|
],
|
||||||
"query": "{\"memberships__club__name\": \"BDE\", \"memberships__roles__name\": \"Adhérent BDE\", \"memberships__date_start__lte\": [\"today\"], \"memberships__date_end__gte\": [\"today\"]}",
|
"query": "{\"memberships__club__name\": \"BDE\", \"memberships__roles__name\": \"Adhérent⋅e BDE\", \"memberships__date_start__lte\": [\"today\"], \"memberships__date_end__gte\": [\"today\"]}",
|
||||||
"type": "view",
|
"type": "view",
|
||||||
"mask": 2,
|
"mask": 2,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Voir n'importe quel utilisateur qui est adhérent BDE"
|
"description": "Voir n'importe quel⋅le utilisateur⋅rice qui est adhérent⋅e BDE"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -3044,7 +3044,7 @@
|
||||||
"mask": 3,
|
"mask": 3,
|
||||||
"field": "",
|
"field": "",
|
||||||
"permanent": false,
|
"permanent": false,
|
||||||
"description": "Voir toutes les amitiés, y compris celles des non adhérents"
|
"description": "Voir toutes les amitiés, y compris celles des non adhérent⋅es"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -3116,7 +3116,7 @@
|
||||||
"pk": 1,
|
"pk": 1,
|
||||||
"fields": {
|
"fields": {
|
||||||
"for_club": 1,
|
"for_club": 1,
|
||||||
"name": "Adh\u00e9rent BDE",
|
"name": "Adh\u00e9rent\u22c5e BDE",
|
||||||
"permissions": [
|
"permissions": [
|
||||||
1,
|
1,
|
||||||
2,
|
2,
|
||||||
|
@ -3161,7 +3161,7 @@
|
||||||
"pk": 2,
|
"pk": 2,
|
||||||
"fields": {
|
"fields": {
|
||||||
"for_club": 2,
|
"for_club": 2,
|
||||||
"name": "Adh\u00e9rent Kfet",
|
"name": "Adh\u00e9rent\u22c5e Kfet",
|
||||||
"permissions": [
|
"permissions": [
|
||||||
22,
|
22,
|
||||||
36,
|
36,
|
||||||
|
@ -3225,7 +3225,7 @@
|
||||||
"pk": 5,
|
"pk": 5,
|
||||||
"fields": {
|
"fields": {
|
||||||
"for_club": null,
|
"for_club": null,
|
||||||
"name": "Pr\u00e9sident\u00b7e de club",
|
"name": "Pr\u00e9sident\u22c5e de club",
|
||||||
"permissions": [
|
"permissions": [
|
||||||
62,
|
62,
|
||||||
142,
|
142,
|
||||||
|
@ -3238,7 +3238,7 @@
|
||||||
"pk": 6,
|
"pk": 6,
|
||||||
"fields": {
|
"fields": {
|
||||||
"for_club": null,
|
"for_club": null,
|
||||||
"name": "Tr\u00e9sorier\u00b7\u00e8re de club",
|
"name": "Tr\u00e9sorièr\u22c5e de club",
|
||||||
"permissions": [
|
"permissions": [
|
||||||
19,
|
19,
|
||||||
20,
|
20,
|
||||||
|
@ -3262,7 +3262,7 @@
|
||||||
"pk": 7,
|
"pk": 7,
|
||||||
"fields": {
|
"fields": {
|
||||||
"for_club": 1,
|
"for_club": 1,
|
||||||
"name": "Pr\u00e9sident\u00b7e BDE",
|
"name": "Pr\u00e9sident\u22c5e BDE",
|
||||||
"permissions": [
|
"permissions": [
|
||||||
24,
|
24,
|
||||||
25,
|
25,
|
||||||
|
@ -3291,7 +3291,7 @@
|
||||||
"pk": 8,
|
"pk": 8,
|
||||||
"fields": {
|
"fields": {
|
||||||
"for_club": 1,
|
"for_club": 1,
|
||||||
"name": "Tr\u00e9sorier\u00b7\u00e8re BDE",
|
"name": "Tr\u00e9sorièr\u22c5e BDE",
|
||||||
"permissions": [
|
"permissions": [
|
||||||
23,
|
23,
|
||||||
24,
|
24,
|
||||||
|
@ -3459,7 +3459,7 @@
|
||||||
"pk": 13,
|
"pk": 13,
|
||||||
"fields": {
|
"fields": {
|
||||||
"for_club": null,
|
"for_club": null,
|
||||||
"name": "Chef de bus",
|
"name": "Chef\u22c5fe de bus",
|
||||||
"permissions": [
|
"permissions": [
|
||||||
22,
|
22,
|
||||||
84,
|
84,
|
||||||
|
@ -3478,7 +3478,7 @@
|
||||||
"pk": 14,
|
"pk": 14,
|
||||||
"fields": {
|
"fields": {
|
||||||
"for_club": null,
|
"for_club": null,
|
||||||
"name": "Chef d'\u00e9quipe",
|
"name": "Chef\u22c5fe d'\u00e9quipe",
|
||||||
"permissions": [
|
"permissions": [
|
||||||
22,
|
22,
|
||||||
84,
|
84,
|
||||||
|
@ -3527,7 +3527,7 @@
|
||||||
"pk": 18,
|
"pk": 18,
|
||||||
"fields": {
|
"fields": {
|
||||||
"for_club": null,
|
"for_club": null,
|
||||||
"name": "Adhérent WEI",
|
"name": "Adhérent\u22c5e WEI",
|
||||||
"permissions": [
|
"permissions": [
|
||||||
77,
|
77,
|
||||||
114
|
114
|
||||||
|
|
|
@ -36,8 +36,8 @@ class RightsTable(tables.Table):
|
||||||
|
|
||||||
def render_roles(self, record):
|
def render_roles(self, record):
|
||||||
# If the user has the right to manage the roles, display the link to manage them
|
# If the user has the right to manage the roles, display the link to manage them
|
||||||
roles = record.roles.filter((~(Q(name="Adhérent BDE")
|
roles = record.roles.filter((~(Q(name="Adhérent⋅e BDE")
|
||||||
| Q(name="Adhérent Kfet")
|
| Q(name="Adhérent⋅e Kfet")
|
||||||
| Q(name="Membre de club")
|
| Q(name="Membre de club")
|
||||||
| Q(name="Bureau de club"))
|
| Q(name="Bureau de club"))
|
||||||
& Q(weirole__isnull=True))).all()
|
& Q(weirole__isnull=True))).all()
|
||||||
|
|
|
@ -58,7 +58,7 @@ class OAuth2TestCase(TestCase):
|
||||||
# Create membership to validate permissions
|
# Create membership to validate permissions
|
||||||
NoteUser.objects.create(user=self.user)
|
NoteUser.objects.create(user=self.user)
|
||||||
membership = Membership.objects.create(user=self.user, club_id=bde.pk)
|
membership = Membership.objects.create(user=self.user, club_id=bde.pk)
|
||||||
membership.roles.add(Role.objects.get(name="Adhérent BDE"))
|
membership.roles.add(Role.objects.get(name="Adhérent⋅e BDE"))
|
||||||
membership.save()
|
membership.save()
|
||||||
|
|
||||||
# User is now a member and can now see its own user detail
|
# User is now a member and can now see its own user detail
|
||||||
|
@ -85,7 +85,7 @@ class OAuth2TestCase(TestCase):
|
||||||
bde = Club.objects.get(name="BDE")
|
bde = Club.objects.get(name="BDE")
|
||||||
NoteUser.objects.create(user=self.user)
|
NoteUser.objects.create(user=self.user)
|
||||||
membership = Membership.objects.create(user=self.user, club_id=bde.pk)
|
membership = Membership.objects.create(user=self.user, club_id=bde.pk)
|
||||||
membership.roles.add(Role.objects.get(name="Adhérent BDE"))
|
membership.roles.add(Role.objects.get(name="Adhérent⋅e BDE"))
|
||||||
membership.save()
|
membership.save()
|
||||||
|
|
||||||
resp = self.client.get(reverse('permission:scopes'))
|
resp = self.client.get(reverse('permission:scopes'))
|
||||||
|
|
|
@ -131,8 +131,8 @@ class RightsView(TemplateView):
|
||||||
special_memberships = Membership.objects.filter(
|
special_memberships = Membership.objects.filter(
|
||||||
date_start__lte=date.today(),
|
date_start__lte=date.today(),
|
||||||
date_end__gte=date.today(),
|
date_end__gte=date.today(),
|
||||||
).filter(roles__in=Role.objects.filter((~(Q(name="Adhérent BDE")
|
).filter(roles__in=Role.objects.filter((~(Q(name="Adhérent⋅e BDE")
|
||||||
| Q(name="Adhérent Kfet")
|
| Q(name="Adhérent⋅e Kfet")
|
||||||
| Q(name="Membre de club")
|
| Q(name="Membre de club")
|
||||||
| Q(name="Bureau de club"))
|
| Q(name="Bureau de club"))
|
||||||
& Q(weirole__isnull=True))))\
|
& Q(weirole__isnull=True))))\
|
||||||
|
|
|
@ -377,7 +377,7 @@ class FutureUserDetailView(ProtectQuerysetMixin, LoginRequiredMixin, FormMixin,
|
||||||
# membership._soge = True
|
# membership._soge = True
|
||||||
membership.save()
|
membership.save()
|
||||||
membership.refresh_from_db()
|
membership.refresh_from_db()
|
||||||
membership.roles.add(Role.objects.get(name="Adhérent BDE"))
|
membership.roles.add(Role.objects.get(name="Adhérent⋅e BDE"))
|
||||||
membership.save()
|
membership.save()
|
||||||
|
|
||||||
if join_kfet:
|
if join_kfet:
|
||||||
|
@ -391,7 +391,7 @@ class FutureUserDetailView(ProtectQuerysetMixin, LoginRequiredMixin, FormMixin,
|
||||||
# membership._soge = True
|
# membership._soge = True
|
||||||
membership.save()
|
membership.save()
|
||||||
membership.refresh_from_db()
|
membership.refresh_from_db()
|
||||||
membership.roles.add(Role.objects.get(name="Adhérent Kfet"))
|
membership.roles.add(Role.objects.get(name="Adhérent⋅e Kfet"))
|
||||||
membership.save()
|
membership.save()
|
||||||
|
|
||||||
for club, join_club in join_clubs:
|
for club, join_club in join_clubs:
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit f580f9b9e9beee76605975fdbc3a2014769e3c61
|
Subproject commit 472c9c33cea3a9c277033f2108fd81304fb62097
|
|
@ -74,7 +74,7 @@ class WEIChooseBusForm(forms.Form):
|
||||||
queryset=WEIRole.objects.filter(~Q(name="1A")),
|
queryset=WEIRole.objects.filter(~Q(name="1A")),
|
||||||
label=_("WEI Roles"),
|
label=_("WEI Roles"),
|
||||||
help_text=_("Select the roles that you are interested in."),
|
help_text=_("Select the roles that you are interested in."),
|
||||||
initial=WEIRole.objects.filter(name="Adhérent WEI").all(),
|
initial=WEIRole.objects.filter(name="Adhérent⋅e WEI").all(),
|
||||||
widget=CheckboxSelectMultiple(),
|
widget=CheckboxSelectMultiple(),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -84,5 +84,5 @@ class Command(BaseCommand):
|
||||||
s += sep + user.profile.section_generated
|
s += sep + user.profile.section_generated
|
||||||
s += sep + bus.name
|
s += sep + bus.name
|
||||||
s += sep + (team.name if team else "--")
|
s += sep + (team.name if team else "--")
|
||||||
s += sep + ", ".join(role.name for role in membership.roles.filter(~Q(name="Adhérent WEI")).all())
|
s += sep + ", ".join(role.name for role in membership.roles.filter(~Q(name="Adhérent⋅e WEI")).all())
|
||||||
self.stdout.write(s)
|
self.stdout.write(s)
|
||||||
|
|
|
@ -504,7 +504,7 @@ class TestWEIRegistration(TestCase):
|
||||||
emergency_contact_phone='+33600000000',
|
emergency_contact_phone='+33600000000',
|
||||||
bus=[self.bus.id],
|
bus=[self.bus.id],
|
||||||
team=[self.team.id],
|
team=[self.team.id],
|
||||||
roles=[role.id for role in WEIRole.objects.filter(name="Adhérent WEI").all()],
|
roles=[role.id for role in WEIRole.objects.filter(name="Adhérent⋅e WEI").all()],
|
||||||
information_json=self.registration.information_json,
|
information_json=self.registration.information_json,
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
@ -558,7 +558,7 @@ class TestWEIRegistration(TestCase):
|
||||||
emergency_contact_phone='+33600000000',
|
emergency_contact_phone='+33600000000',
|
||||||
bus=[self.bus.id],
|
bus=[self.bus.id],
|
||||||
team=[self.team.id],
|
team=[self.team.id],
|
||||||
roles=[role.id for role in WEIRole.objects.filter(name="Adhérent WEI").all()],
|
roles=[role.id for role in WEIRole.objects.filter(name="Adhérent⋅e WEI").all()],
|
||||||
information_json=self.registration.information_json,
|
information_json=self.registration.information_json,
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
|
@ -916,7 +916,7 @@ class WEIValidateRegistrationView(ProtectQuerysetMixin, ProtectedCreateView):
|
||||||
form["team"].initial = BusTeam.objects.get(pk=information["preferred_team_pk"][0])
|
form["team"].initial = BusTeam.objects.get(pk=information["preferred_team_pk"][0])
|
||||||
if "preferred_roles_pk" in information:
|
if "preferred_roles_pk" in information:
|
||||||
form["roles"].initial = WEIRole.objects.filter(
|
form["roles"].initial = WEIRole.objects.filter(
|
||||||
Q(pk__in=information["preferred_roles_pk"]) | Q(name="Adhérent WEI")
|
Q(pk__in=information["preferred_roles_pk"]) | Q(name="Adhérent⋅e WEI")
|
||||||
).all()
|
).all()
|
||||||
return form
|
return form
|
||||||
|
|
||||||
|
@ -1008,7 +1008,7 @@ class WEIValidateRegistrationView(ProtectQuerysetMixin, ProtectedCreateView):
|
||||||
|
|
||||||
membership.save()
|
membership.save()
|
||||||
membership.refresh_from_db()
|
membership.refresh_from_db()
|
||||||
membership.roles.add(WEIRole.objects.get(name="Adhérent WEI"))
|
membership.roles.add(WEIRole.objects.get(name="Adhérent⋅e WEI"))
|
||||||
|
|
||||||
return super().form_valid(form)
|
return super().form_valid(form)
|
||||||
|
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 143 KiB After Width: | Height: | Size: 150 KiB |
|
@ -23,7 +23,7 @@ Pages de l'API
|
||||||
Il suffit d'ajouter le préfixe ``/api/`` pour arriver sur ces pages.
|
Il suffit d'ajouter le préfixe ``/api/`` pour arriver sur ces pages.
|
||||||
|
|
||||||
* `models <basic#type-de-contenu>`_ : liste des différents modèles enregistrés en base de données
|
* `models <basic#type-de-contenu>`_ : liste des différents modèles enregistrés en base de données
|
||||||
* `user <basic#utilisateur>`_ : liste des différents utilisateurs enregistrés
|
* `user <basic#utilisateur>`_ : liste des différent⋅es utilisateur⋅rices enregistrés
|
||||||
* `members/profile <member#profil-utilisateur>`_ : liste des différents profils associés à des utilisateurs
|
* `members/profile <member#profil-utilisateur>`_ : liste des différents profils associés à des utilisateurs
|
||||||
* `members/club <member#club>`_ : liste des différents clubs enregistrés
|
* `members/club <member#club>`_ : liste des différents clubs enregistrés
|
||||||
* `members/membership <member#adhesion>`_ : liste des adhésions enregistrées
|
* `members/membership <member#adhesion>`_ : liste des adhésions enregistrées
|
||||||
|
@ -69,7 +69,7 @@ S'authentifier
|
||||||
|
|
||||||
L'authentification peut se faire soit par session en se connectant via la page de connexion classique,
|
L'authentification peut se faire soit par session en se connectant via la page de connexion classique,
|
||||||
soit via un jeton d'authentification. Le jeton peut se récupérer via la page de son propre compte, en cliquant
|
soit via un jeton d'authentification. Le jeton peut se récupérer via la page de son propre compte, en cliquant
|
||||||
sur le bouton « `Accès API <https://note.crans.org/accounts/manage-auth-token/>`_ ». Il peut être révoqué et regénéré
|
sur le bouton « `Accès API <https://note.crans.org/accounts/manage-auth-token/>`_ ». Il peut être révoqué et régénéré
|
||||||
en un clic.
|
en un clic.
|
||||||
|
|
||||||
Pour s'authentifier via ce jeton, il faut ajouter l'en-tête ``Authorization: Token <TOKEN>`` aux paramètres HTTP.
|
Pour s'authentifier via ce jeton, il faut ajouter l'en-tête ``Authorization: Token <TOKEN>`` aux paramètres HTTP.
|
||||||
|
@ -111,7 +111,7 @@ Trois types de filtres sont implémentés :
|
||||||
|
|
||||||
Les filtres disponibles sont indiqués sur chacune des pages de documentation.
|
Les filtres disponibles sont indiqués sur chacune des pages de documentation.
|
||||||
|
|
||||||
Le résultat est déjà par défaut filtré par droits : seuls les éléments que l'utilisateur à le droit de voir sont affichés.
|
Le résultat est déjà par défaut filtré par droits : seuls les éléments que l'utilisateur⋅rice a le droit de voir sont affichés.
|
||||||
Cela est possible grâce à la structure des permissions, générant justement des filtres de requêtes de base de données.
|
Cela est possible grâce à la structure des permissions, générant justement des filtres de requêtes de base de données.
|
||||||
|
|
||||||
Une requête à l'adresse ``/api/<model>/<pk>/`` affiche directement les informations du modèle demandé au format JSON.
|
Une requête à l'adresse ``/api/<model>/<pk>/`` affiche directement les informations du modèle demandé au format JSON.
|
||||||
|
@ -126,8 +126,9 @@ Des exceptions sont faites sur certaines pages : les pages de logs et de content
|
||||||
|
|
||||||
Les formats supportés sont multiples : ``application/json``, ``application/x-www-url-encoded``, ``multipart/form-data``.
|
Les formats supportés sont multiples : ``application/json``, ``application/x-www-url-encoded``, ``multipart/form-data``.
|
||||||
Cela facilite l'envoi de requêtes. Le module construit ensuite l'instance du modèle et le sauvegarde dans la base de
|
Cela facilite l'envoi de requêtes. Le module construit ensuite l'instance du modèle et le sauvegarde dans la base de
|
||||||
données. L'application ``permission`` s'assure que l'utilisateur à le droit de faire ce type de modification. La réponse
|
données. L'application ``permission`` s'assure que l'utilisateur⋅rice a le droit de faire ce type de modification.
|
||||||
renvoyée est l'objet enregistré au format JSON si l'ajout s'est bien déroulé, sinon un message d'erreur au format JSON.
|
La réponse renvoyée est l'objet enregistré au format JSON si l'ajout s'est bien déroulé, sinon un message d'erreur au
|
||||||
|
format JSON.
|
||||||
|
|
||||||
PATCH
|
PATCH
|
||||||
~~~~~
|
~~~~~
|
||||||
|
|
|
@ -135,7 +135,7 @@ Options
|
||||||
"required": false,
|
"required": false,
|
||||||
"read_only": false,
|
"read_only": false,
|
||||||
"label": "Pay\u00e9",
|
"label": "Pay\u00e9",
|
||||||
"help_text": "Indique si l'utilisateur per\u00e7oit un salaire."
|
"help_text": "Indique si l'utilisateur⋅rice per\u00e7oit un salaire."
|
||||||
},
|
},
|
||||||
"ml_events_registration": {
|
"ml_events_registration": {
|
||||||
"type": "choice",
|
"type": "choice",
|
||||||
|
|
|
@ -511,7 +511,7 @@ Options
|
||||||
"required": false,
|
"required": false,
|
||||||
"read_only": false,
|
"read_only": false,
|
||||||
"label": "Premi\u00e8re ann\u00e9e",
|
"label": "Premi\u00e8re ann\u00e9e",
|
||||||
"help_text": "Indique si l'utilisateur est nouveau dans l'\u00e9cole."
|
"help_text": "Indique si l'utilisateur⋅rice est nouvelleau dans l'\u00e9cole."
|
||||||
},
|
},
|
||||||
"information_json": {
|
"information_json": {
|
||||||
"type": "string",
|
"type": "string",
|
||||||
|
@ -524,7 +524,7 @@ Options
|
||||||
"type": "field",
|
"type": "field",
|
||||||
"required": true,
|
"required": true,
|
||||||
"read_only": false,
|
"read_only": false,
|
||||||
"label": "Utilisateur"
|
"label": "Utilisateur⋅rice"
|
||||||
},
|
},
|
||||||
"wei": {
|
"wei": {
|
||||||
"type": "field",
|
"type": "field",
|
||||||
|
|
|
@ -3,12 +3,12 @@ Application Activités
|
||||||
|
|
||||||
L'application activités gère les différentes activités liées au BDE. Elle permet entre autres de créer des activités qui
|
L'application activités gère les différentes activités liées au BDE. Elle permet entre autres de créer des activités qui
|
||||||
peuvent être diffusées via des calendriers ou la mailing list d'événements. Elle permet aussi de réguler l'accès aux
|
peuvent être diffusées via des calendriers ou la mailing list d'événements. Elle permet aussi de réguler l'accès aux
|
||||||
événements, en s'assurant que leur note est positive. Elle permet enfin de gérer les invités.
|
événements, en s'assurant que leur note est positive. Elle permet enfin de gérer les invité⋅es.
|
||||||
|
|
||||||
Modèles
|
Modèles
|
||||||
-------
|
-------
|
||||||
|
|
||||||
L'application comporte 5 modèles : activités, types d'activité, invités, entrées et transactions d'invitation.
|
L'application comporte 5 modèles : activités, types d'activité, invité⋅es, entrées et transactions d'invitation.
|
||||||
|
|
||||||
Types d'activité
|
Types d'activité
|
||||||
~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~
|
||||||
|
@ -16,7 +16,7 @@ Types d'activité
|
||||||
Les activités sont triées par type (pots, soirées de club, ...), et chaque type regroupe diverses informations :
|
Les activités sont triées par type (pots, soirées de club, ...), et chaque type regroupe diverses informations :
|
||||||
|
|
||||||
* Nom du type
|
* Nom du type
|
||||||
* Possibilité d'inviter des non-adhérents (booléen)
|
* Possibilité d'inviter des non-adhérent⋅es (booléen)
|
||||||
* Prix d'invitation (entier, centimes à débiter sur la note de l'hôte)
|
* Prix d'invitation (entier, centimes à débiter sur la note de l'hôte)
|
||||||
|
|
||||||
Activités
|
Activités
|
||||||
|
@ -26,7 +26,7 @@ Le modèle d'activité regroupe les informations liées à l'activité même :
|
||||||
|
|
||||||
* Nom de l'activité
|
* Nom de l'activité
|
||||||
* Description de l'activité
|
* Description de l'activité
|
||||||
* Créateur, personne qui a proposé l'activité
|
* Créateur⋅rice, personne qui a proposé l'activité
|
||||||
* Club ayant organisé l'activité
|
* Club ayant organisé l'activité
|
||||||
* Note sur laquelle verser les crédits d'invitation (peut être nul si non concerné)
|
* Note sur laquelle verser les crédits d'invitation (peut être nul si non concerné)
|
||||||
* Club invité (généralement le club Kfet)
|
* Club invité (généralement le club Kfet)
|
||||||
|
@ -38,19 +38,19 @@ Le modèle d'activité regroupe les informations liées à l'activité même :
|
||||||
Entrées
|
Entrées
|
||||||
~~~~~~~
|
~~~~~~~
|
||||||
|
|
||||||
Une instance de ce modèle est créé dès que quelqu'un est inscrit à l'activité. Sont stockées les informations suivantes :
|
Une instance de ce modèle est créé dès que quelqu'un⋅e est inscrit⋅e à l'activité. Sont stockées les informations suivantes :
|
||||||
|
|
||||||
* Activité concernée (clé étrangère)
|
* Activité concernée (clé étrangère)
|
||||||
* Heure d'entrée
|
* Heure d'entrée
|
||||||
* Note de la personne entrée, ou hôte s'il s'agit d'un invité (clé étrangère vers ``NoteUser``)
|
* Note de la personne entrée, ou hôte s'il s'agit d'un⋅e invité⋅e (clé étrangère vers ``NoteUser``)
|
||||||
* Invité (``OneToOneField`` vers ``Guest``, ``None`` si c'est la personne elle-même qui rentre et non son invité)
|
* Invité⋅e (``OneToOneField`` vers ``Guest``, ``None`` si c'est la personne elle-même qui rentre et non saon invité⋅e)
|
||||||
|
|
||||||
Il n'est pas possible de créer une entrée si la note est en négatif.
|
Il n'est pas possible de créer une entrée si la note est en négatif.
|
||||||
|
|
||||||
Invités
|
Invité⋅es
|
||||||
~~~~~~~
|
~~~~~~~~~
|
||||||
|
|
||||||
Les adhérents ont la possibilité d'inviter des amis. Pour cela, les différentes informations sont enregistrées :
|
Les adhérent⋅es ont la possibilité d'inviter des ami⋅es. Pour cela, les différentes informations sont enregistrées :
|
||||||
|
|
||||||
* Activité concernée (clé étrangère)
|
* Activité concernée (clé étrangère)
|
||||||
* Nom de famille
|
* Nom de famille
|
||||||
|
@ -60,7 +60,7 @@ Les adhérents ont la possibilité d'inviter des amis. Pour cela, les différent
|
||||||
Certaines contraintes s'appliquent :
|
Certaines contraintes s'appliquent :
|
||||||
|
|
||||||
* Une personne ne peut pas être invitée plus de 5 fois par an (coupe nom/prénom)
|
* Une personne ne peut pas être invitée plus de 5 fois par an (coupe nom/prénom)
|
||||||
* Un adhérent ne peut pas inviter plus de 3 personnes par activité.
|
* Un⋅e adhérent⋅e ne peut pas inviter plus de 3 personnes par activité.
|
||||||
|
|
||||||
Transactions d'invitation
|
Transactions d'invitation
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
@ -83,15 +83,15 @@ UI
|
||||||
Création d'activités
|
Création d'activités
|
||||||
~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
N'importe quel adhérent Kfet peut suggérer l'ajout d'une activité via un formulaire.
|
N'importe quel⋅le adhérent⋅e Kfet peut suggérer l'ajout d'une activité via un formulaire.
|
||||||
|
|
||||||
Gestion des activités
|
Gestion des activités
|
||||||
~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Les ayant-droit (Res[pot] et respos infos) peuvent valider les activités proposées. Ils peuvent également la modifier
|
Les ayant-droit (Res[pot] et respos infos) peuvent valider les activités proposées. Ils peuvent également la modifier
|
||||||
si besoin. Ils peuvent enfin la déclarer ouvertes pour lancer l'accès aux entrées.
|
si besoin. Iels peuvent enfin la déclarer ouverte pour lancer l'accès aux entrées.
|
||||||
|
|
||||||
N'importe qui peut inviter des amis non adhérents, tant que les contraintes de nombre (un adhérent n'invite pas plus de
|
N'importe qui peut inviter des ami⋅es non adhérent⋅es, tant que les contraintes de nombre (un⋅e adhérent⋅e n'invite pas plus de
|
||||||
trois personnes par activité et une personne ne peut pas être invitée plus de 5 fois par an). L'invitation est
|
trois personnes par activité et une personne ne peut pas être invitée plus de 5 fois par an). L'invitation est
|
||||||
facturée à l'entrée.
|
facturée à l'entrée.
|
||||||
|
|
||||||
|
@ -99,12 +99,12 @@ Entrées aux soirées
|
||||||
~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
L'interface d'entrées est simple et ergonomique. Elle contient un champ de texte. À chaque fois que le champ est
|
L'interface d'entrées est simple et ergonomique. Elle contient un champ de texte. À chaque fois que le champ est
|
||||||
modifié, un tableau est affiché comprenant la liste des invités et des adhérents dont le prénom, le nom ou un alias
|
modifié, un tableau est affiché comprenant la liste des invité⋅es et des adhérent⋅es dont le prénom, le nom ou un alias
|
||||||
de la note est acceptée par le texte entré.
|
de la note est acceptée par le texte entré.
|
||||||
|
|
||||||
En cliquant sur la ligne de la personne qui souhaite rentrée, s'il s'agit d'un adhérent, alors la personne est comptée
|
En cliquant sur la ligne de la personne qui souhaite rentrer, s'il s'agit d'un⋅e adhérent⋅e, alors la personne est comptée
|
||||||
comme entrée à l'activité, sous réserve que sa note soit positive. S'il s'agit d'un invité, alors 3 boutons
|
comme entrée à l'activité, sous réserve que sa note soit positive. S'il s'agit d'un⋅e invité⋅e, alors 3 boutons
|
||||||
apparaîssent, afin de régler la taxe d'invitation : l'un prélève directement depuis la note de l'hôte, les deux autres
|
apparaîssent, afin de régler la taxe d'invitation : l'un prélève directement depuis la note de l'hôte, les deux autres
|
||||||
permettent un paiement par espèces ou par carte bancaire. En réalité, les deux derniers boutons enregistrent
|
permettent un paiement par espèces ou par carte bancaire. En réalité, les deux derniers boutons enregistrent
|
||||||
automatiquement un crédit sur la note de l'hôte, puis une transaction (de type ``GuestTransaction``) est faite depuis
|
automatiquement un crédit sur la note de l'hôte, puis une transaction (de type ``GuestTransaction``) est faite depuis
|
||||||
la note de l'hôte vers la note de l'organisateur de l'événement.
|
la note de l'hôte vers la note du club organisateur de l'événement.
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
Applications de la NoteKfet2020
|
Applications de la Note Kfet 2020
|
||||||
===============================
|
=================================
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: 2
|
:maxdepth: 2
|
||||||
|
@ -15,27 +15,26 @@ Applications de la NoteKfet2020
|
||||||
treasury
|
treasury
|
||||||
wei
|
wei
|
||||||
|
|
||||||
La NoteKfet est un projet Django, décomposé en applications.
|
La Note Kfet 2020 est un projet Django, décomposé en applications.
|
||||||
Certaines Applications sont développées uniquement pour ce projet, et sont indispensables,
|
Certaines applications sont développées uniquement pour ce projet, et sont indispensables,
|
||||||
d'autres sont packagesé et sont installées comme dépendances.
|
d'autres sont packagées et sont installées comme dépendances.
|
||||||
Enfin des fonctionnalités annexes ont été rajouté, mais ne sont pas essentiel au déploiement de la NoteKfet;
|
Enfin, des fonctionnalités annexes ont été rajoutées, mais ne sont pas essentielles au déploiement de la Note Kfet 2020. Leur usage est cependant recommandé.
|
||||||
leur usage est cependant recommandé.
|
|
||||||
|
|
||||||
Le front utilise le framework Bootstrap4 et quelques morceaux de javascript custom.
|
L'affichage Web utilise le framework Bootstrap4 et quelques morceaux de JavaScript personnalisés.
|
||||||
|
|
||||||
Applications indispensables
|
Applications indispensables
|
||||||
---------------------------
|
---------------------------
|
||||||
|
|
||||||
* ``note_kfet`` :
|
* ``note_kfet`` :
|
||||||
Application "projet" de django, c'est ici que la config de la note est gérée.
|
Application "projet" de django, c'est ici que la configuration de la note est gérée.
|
||||||
* `Member <member>`_ :
|
* `Member <member>`_ :
|
||||||
Gestion des profils d'utilisateurs, des clubs et de leur membres.
|
Gestion des profils d'utilisateur⋅rices, des clubs et de leur membres.
|
||||||
* `Note <note>`_ :
|
* `Note <note>`_ :
|
||||||
Les notes associés a des utilisateurs ou des clubs.
|
Les notes associées à des utilisateur⋅rices ou des clubs.
|
||||||
* `Activity <activity>`_ :
|
* `Activity <activity>`_ :
|
||||||
La gestion des Activités (créations, gestion, entrée...)
|
La gestion des activités (créations, gestion, entrées,…)
|
||||||
* `Permission <permission>`_ :
|
* `Permission <permission>`_ :
|
||||||
Backend de droits, limites les pouvoirs des utilisateurs
|
Backend de droits, limites les pouvoirs des utilisateur⋅rices
|
||||||
* `API <../api>`_ :
|
* `API <../api>`_ :
|
||||||
API REST de la note, est notamment utilisée pour rendre la note dynamique
|
API REST de la note, est notamment utilisée pour rendre la note dynamique
|
||||||
(notamment la page de conso)
|
(notamment la page de conso)
|
||||||
|
@ -52,9 +51,9 @@ Applications packagées
|
||||||
`<https://django-polymorphic.readthedocs.io/en/stable/>`_
|
`<https://django-polymorphic.readthedocs.io/en/stable/>`_
|
||||||
|
|
||||||
* ``crispy_forms``
|
* ``crispy_forms``
|
||||||
Utiliser pour générer des forms avec bootstrap4
|
Utiliser pour générer des formulaires avec Bootstrap4
|
||||||
* ``django_tables2``
|
* ``django_tables2``
|
||||||
utiliser pour afficher des tables de données et les formater, en python plutôt qu'en HTML.
|
utiliser pour afficher des tables de données et les formater, en Python plutôt qu'en HTML.
|
||||||
* ``restframework``
|
* ``restframework``
|
||||||
Base de l'`API <../api>`_.
|
Base de l'`API <../api>`_.
|
||||||
|
|
||||||
|
@ -63,11 +62,11 @@ Applications facultatives
|
||||||
* `Logs <logs>`_
|
* `Logs <logs>`_
|
||||||
Enregistre toute les modifications effectuées en base de donnée.
|
Enregistre toute les modifications effectuées en base de donnée.
|
||||||
* ``cas-server``
|
* ``cas-server``
|
||||||
Serveur central d'authenfication, permet d'utiliser son compte de la NoteKfet2020 pour se connecter à d'autre application ayant intégrer un client.
|
Serveur central d'authentification, permet d'utiliser son compte de la NoteKfet2020 pour se connecter à d'autre application ayant intégrer un client.
|
||||||
* `Script <https://gitlab.crans.org/bde/nk20-scripts>`_
|
* `Scripts <https://gitlab.crans.org/bde/nk20-scripts>`_
|
||||||
Ensemble de commande `./manage.py` pour la gestion de la note: import de données, verification d'intégrité, etc ...
|
Ensemble de commande `./manage.py` pour la gestion de la note: import de données, verification d'intégrité, etc…
|
||||||
* `Treasury <treasury>`_ :
|
* `Treasury <treasury>`_ :
|
||||||
Interface de gestion pour les trésoriers, émission de facture, remise de chèque, statistiques ...
|
Interface de gestion pour les trésorièr⋅es, émission de factures, remises de chèque, statistiques ...
|
||||||
* `WEI <wei>`_ :
|
* `WEI <wei>`_ :
|
||||||
Interface de gestion du WEI.
|
Interface de gestion du WEI.
|
||||||
|
|
||||||
|
|
|
@ -6,22 +6,22 @@ Chaque modification effectuée sur un modèle est enregistrée dans la base dans
|
||||||
Dès qu'un modèle veut être sauvegardé, deux signaux sont envoyés dans ``logs.signals`` : un avant et un après
|
Dès qu'un modèle veut être sauvegardé, deux signaux sont envoyés dans ``logs.signals`` : un avant et un après
|
||||||
la sauvegarde.
|
la sauvegarde.
|
||||||
En pré-sauvegarde, on récupère l'ancienne version du modèle, si elle existe.
|
En pré-sauvegarde, on récupère l'ancienne version du modèle, si elle existe.
|
||||||
En post-sauvegarde, on récupère l'utilisateur et l'IP courants (voir ci-dessous), on convertit les modèles en JSON
|
En post-sauvegarde, on récupère l'utilisateur⋅rice et l'IP courant⋅es (voir ci-dessous), on convertit les modèles en JSON
|
||||||
et on enregistre une entrée ``Changelog`` dans la base de données.
|
et on enregistre une entrée ``Changelog`` dans la base de données.
|
||||||
|
|
||||||
Pour récupérer l'utilisateur et son IP, le middleware ``logs.middlewares.LogsMiddlewares`` récupère à chaque requête
|
Pour récupérer l'utilisateur⋅rice et son IP, le middleware ``logs.middlewares.LogsMiddlewares`` récupère à chaque requête
|
||||||
l'utilisateur et l'adresse IP, et les stocke dans le processus courant, afin qu'ils puissent être
|
l'utilisateur⋅rice et l'adresse IP, et les stocke dans le processus courant, afin qu'ils puissent être
|
||||||
récupérés par les signaux.
|
récupérés par les signaux.
|
||||||
|
|
||||||
Si jamais la modification ne provient pas d'une requête Web, on suppose qu'elle vient d'une instruction
|
Si jamais la modification ne provient pas d'une requête Web, on suppose qu'elle vient d'une instruction
|
||||||
lancée avec ``manage.py``.
|
lancée avec ``manage.py``.
|
||||||
On récupère alors le nom de l'utilisateur dans l'interface de commandes, et si une note est associée à cet alias,
|
On récupère alors le nom de l'utilisateur⋅rice dans l'interface de commandes, et si une note est associée à cet alias,
|
||||||
alors on considère que c'est le détenteur de la note qui a effectué cette modification, sur l'adresse IP ``127.0.0.1``.
|
alors on considère que c'est le détenteur de la note qui a effectué cette modification, sur l'adresse IP ``127.0.0.1``.
|
||||||
Sinon, le champ est laissé à ``None``.
|
Sinon, le champ est laissé à ``None``.
|
||||||
|
|
||||||
Une entrée de ``Changelog`` contient les informations suivantes :
|
Une entrée de ``Changelog`` contient les informations suivantes :
|
||||||
|
|
||||||
* Utilisateur (``ForeignKey`` vers ``User``, nullable)
|
* Utilisateur⋅rice (``ForeignKey`` vers ``User``, nullable)
|
||||||
* Adresse IP (``GenericIPAddressField``)
|
* Adresse IP (``GenericIPAddressField``)
|
||||||
* Type de modèle enregistré (``ForeignKey`` vers ``Model``)
|
* Type de modèle enregistré (``ForeignKey`` vers ``Model``)
|
||||||
* Identifiant ``pk`` de l'instance enregistrée (``CharField``)
|
* Identifiant ``pk`` de l'instance enregistrée (``CharField``)
|
||||||
|
@ -54,4 +54,4 @@ Graphe
|
||||||
~~~~~~
|
~~~~~~
|
||||||
|
|
||||||
.. image:: ../_static/img/graphs/logs.svg
|
.. image:: ../_static/img/graphs/logs.svg
|
||||||
:alt: Logs graphe
|
:alt: Logs graph
|
||||||
|
|
|
@ -1,63 +1,63 @@
|
||||||
Application Member
|
Application Member
|
||||||
==================
|
==================
|
||||||
|
|
||||||
L'application ``member`` s'occcupe de la gestion des utilisateurs enregistrés.
|
L'application ``member`` s'occcupe de la gestion des utilisateur⋅rices enregistré⋅es.
|
||||||
|
|
||||||
Le model d'utilisateur ``django.contrib.auth.model.User`` est complété par un ``Profile`` utilisateur.
|
Le model d'utilisateur⋅rice ``django.contrib.auth.model.User`` est complété par un ``Profile`` utilisateur⋅rice.
|
||||||
|
|
||||||
Tous les utilisateurs peuvent être membre de ``Club``. Cela se traduit par une adhésion ``Membership``, dont les
|
Toustes les utilisateur⋅rices peuvent être membre de ``Club``. Cela se traduit par une adhésion ``Membership``, dont les
|
||||||
caractéristiques sont propres à chaque club.
|
caractéristiques sont propres à chaque club.
|
||||||
|
|
||||||
En pratique, la NoteKfet possède au minimum deux Club: **Bde** et **Kfet** (instanciés via les fixtures). Et tous
|
En pratique, la Note Kfet possède au minimum deux clubs : **Bde** et **Kfet** (instanciés
|
||||||
les personnes à jour de cotisation sont membre à minima de Bde.
|
via les fixtures). Et toutes les personnes à jour de cotisation sont membre à minima de
|
||||||
Être adhérent du club Kfet permet d'utiliser sa note pour consommer.
|
BDE. Être adhérent⋅e du club Kfet permet d'utiliser sa note pour consommer.
|
||||||
|
|
||||||
Modèles
|
Modèles
|
||||||
-------
|
-------
|
||||||
|
|
||||||
Utilisateur
|
Utilisateur⋅rice
|
||||||
~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Le modèle ``User`` est directement implémenté dans Django et n'appartient pas à l'application ``member``, mais il est
|
Le modèle ``User`` est directement implémenté dans Django et n'appartient pas à l'application ``member``, mais il est
|
||||||
bon de rappeler à quoi ressemble ce modèle.
|
bon de rappeler à quoi ressemble ce modèle.
|
||||||
|
|
||||||
* ``date_joined`` : ``DateTimeField``, date à laquelle l'utilisateur a été inscrit (*inutilisé dans la Note*)
|
* ``date_joined`` : ``DateTimeField``, date à laquelle l'utilisateur⋅rice a été inscrit⋅e (*inutilisé dans la Note*)
|
||||||
* ``email`` : ``EmailField``, adresse e-mail de l'utilisateur.
|
* ``email`` : ``EmailField``, adresse e-mail de l'utilisateur⋅rice.
|
||||||
* ``first_name`` : ``CharField``, prénom de l'utilisateur.
|
* ``first_name`` : ``CharField``, prénom de l'utilisateur⋅rice.
|
||||||
* ``is_active`` : ``BooleanField``, indique si le compte est actif et peut se connecter.
|
* ``is_active`` : ``BooleanField``, indique si le compte est actif et peut se connecter.
|
||||||
* ``is_staff`` : ``BooleanField``, indique si l'utilisateur peut se connecter à l'interface Django-admin.
|
* ``is_staff`` : ``BooleanField``, indique si l'utilisateur⋅rice peut se connecter à l'interface Django-admin.
|
||||||
* ``is_superuser`` : ``BooleanField``, indique si l'utilisateur dispose de droits super-utilisateurs, permettant n'importe quelle action en base de donnée (lecture, ajout, modification, suppression).
|
* ``is_superuser`` : ``BooleanField``, indique si l'utilisateur⋅rice dispose de droits super-utilisateur⋅rices, permettant n'importe quelle action en base de donnée (lecture, ajout, modification, suppression).
|
||||||
* ``last_login`` : ``DateTimeField``, date et heure de dernière connexion.
|
* ``last_login`` : ``DateTimeField``, date et heure de dernière connexion.
|
||||||
* ``last_name`` : ``CharField``, nom de famille de l'utilisateur.
|
* ``last_name`` : ``CharField``, nom de famille de l'utilisateur⋅rice.
|
||||||
* ``password`` : ``CharField``, contient le hash du mot de passe de l'utilisateur. L'algorithme utilisé est celui par défaut de Django : PBKDF2 + HMAC + SHA256 avec 150000 itérations.
|
* ``password`` : ``CharField``, contient le hash du mot de passe de l'utilisateur⋅rice. L'algorithme utilisé est celui par défaut de Django : PBKDF2 + HMAC + SHA256 avec 150000 itérations.
|
||||||
* ``username`` : ``CharField`` (unique), pseudo de l'utilisateur.
|
* ``username`` : ``CharField`` (unique), pseudo de l'utilisateur⋅rice.
|
||||||
|
|
||||||
Profil
|
Profil
|
||||||
~~~~~~
|
~~~~~~
|
||||||
|
|
||||||
Le modèle ``Profile`` contient un champ ``user`` de type ``OneToOneField``, ce qui permet de voir ce modèle comme une
|
Le modèle ``Profile`` contient un champ ``user`` de type ``OneToOneField``, ce qui permet de voir ce modèle comme une
|
||||||
extension du modèle ``User``, sans avoir à le réécrire. Il contient diverses informations personnelles sur
|
extension du modèle ``User``, sans avoir à le réécrire. Il contient diverses informations personnelles sur
|
||||||
l'utilisateur, utiles pour l'adhésion au BDE :
|
l'utilisateur⋅rice, utiles pour l'adhésion au BDE :
|
||||||
|
|
||||||
* ``user`` : ``OneToOneField(User)``, utilisateur lié à ce profil
|
* ``user`` : ``OneToOneField(User)``, utilisateur⋅rice lié à ce profil
|
||||||
* ``address`` : ``CharField``, adresse physique de l'utilisateur
|
* ``address`` : ``CharField``, adresse physique de l'utilisateur⋅rice
|
||||||
* ``paid`` : ``BooleanField``, indique si l'utilisateur normalien est rémunéré ou non (utile pour différencier les montants d'adhésion aux clubs)
|
* ``paid`` : ``BooleanField``, indique si l'utilisateur⋅rice normalien⋅ne est rémunéré⋅e ou non (utile pour différencier les montants d'adhésion aux clubs)
|
||||||
* ``phone_number`` : ``CharField``, numéro de téléphone de l'utilisateur
|
* ``phone_number`` : ``CharField``, numéro de téléphone de l'utilisateur⋅rice
|
||||||
* ``section`` : ``CharField``, section de l'ENS à laquelle apartient l'utilisateur (exemple : 1A0, ...)
|
* ``section`` : ``CharField``, section de l'ENS à laquelle appartient l'utilisateur⋅rice (exemple : 1A0,…)
|
||||||
|
|
||||||
Clubs
|
Clubs
|
||||||
~~~~~
|
~~~~~
|
||||||
|
|
||||||
La gestion des clubs est une différence majeure avec la Note Kfet 2015. La Note gère ainsi les adhésions des
|
La gestion des clubs est une différence majeure avec la Note Kfet 2015. La Note gère ainsi les adhésions des
|
||||||
utilisateurs aux différents clubs.
|
utilisateur⋅rices aux différents clubs.
|
||||||
|
|
||||||
* ``parent_club`` : ``ForeignKey(Club)``. La présence d'un club parent force l'adhésion au club parent avant de pouvoir adhérer au dit club. Tout club qui n'est pas le club BDE doit avoir le club BDE dans son arborescence.
|
* ``parent_club`` : ``ForeignKey(Club)``. La présence d'un club parent force l'adhésion au club parent avant de pouvoir adhérer au dit club. Tout club qui n'est pas le club BDE doit avoir le club BDE dans son arborescence.
|
||||||
* ``email`` : ``EmailField``, adresse e-mail sur laquelle contacter le bureau du club.
|
* ``email`` : ``EmailField``, adresse e-mail sur laquelle contacter le bureau du club.
|
||||||
* ``membership_start`` : ``DateField``, date à partir de laquelle il est possible d'adhérer à un club pour l'année suivante (si adhésions à l'année), en ignorant l'année. Par exemple, l'adhésion BDE est possible à partir du 31/08 par défaut, et c'est à cette date que les adhésions pour l'année future est possible.
|
* ``membership_start`` : ``DateField``, date à partir de laquelle il est possible d'adhérer à un club pour l'année suivante (si adhésions à l'année), en ignorant l'année. Par exemple, l'adhésion BDE est possible à partir du 01/08 par défaut, et c'est à cette date que les adhésions pour l'année future est possible.
|
||||||
* ``membership_end`` : ``DateField``, date maximale de fin d'adhésion. Pour le club BDE, il s'agit du 30/09 de l'année suivante. Si cette valeur vaut ``null``, la fin d'adhésion n'est pas limitée.
|
* ``membership_end`` : ``DateField``, date maximale de fin d'adhésion. Pour le club BDE, il s'agit du 30/09 de l'année suivante. Si cette valeur vaut ``null``, la fin d'adhésion n'est pas limitée.
|
||||||
* ``membership_duration`` : ``PositiveIntegerField``, durée (en jours) maximale d'adhésion. Par exemple, le club BDE permet des adhésions maximales de 13 mois, soit 396 jours.
|
* ``membership_duration`` : ``PositiveIntegerField``, durée (en jours) maximale d'adhésion. Par exemple, le club BDE permet des adhésions maximales de 13 mois, soit 396 jours.
|
||||||
* ``membership_fee_paid`` : ``PositiveIntegerField``, montant de la cotisation (en centimes) pour qu'un élève normalien (donc rémunéré) puisse adhérer.
|
* ``membership_fee_paid`` : ``PositiveIntegerField``, montant de la cotisation (en centimes) pour qu'un⋅e élève normalien⋅ne (donc rémunéré⋅e) puisse adhérer.
|
||||||
* ``membership_fee_unpaid`` : ``PositiveIntegerField``, montant de la cotisation (en centimes) pour qu'un étudiant normalien (donc non rémunéré) puisse adhérer.
|
* ``membership_fee_unpaid`` : ``PositiveIntegerField``, montant de la cotisation (en centimes) pour qu'un⋅e étudiant⋅e normalien⋅ne (donc non rémunéré) puisse adhérer.
|
||||||
* ``name`` : ``CharField``, nom du club.
|
* ``name`` : ``CharField``, nom du club.
|
||||||
* ``require_memberships`` : ``BooleanField``, indique si le club est un vrai club BDE qui nécessite des adhésions de club, ou s'il s'agit d'une note "pot commun" (organisation d'une activité, note de département, ...)
|
* ``require_memberships`` : ``BooleanField``, indique si le club est un vrai club BDE qui nécessite des adhésions de club, ou s'il s'agit d'une note "pot commun" (organisation d'une activité, note de département, ...)
|
||||||
|
|
||||||
|
@ -67,16 +67,16 @@ Adhésions
|
||||||
Comme indiqué précédemment, la note gère les adhésions.
|
Comme indiqué précédemment, la note gère les adhésions.
|
||||||
|
|
||||||
* ``club`` : ``ForeignKey(Club)``, club lié à l'adhésion.
|
* ``club`` : ``ForeignKey(Club)``, club lié à l'adhésion.
|
||||||
* ``user`` : ``ForeignKey(User)``, utilisateur adhéré.
|
* ``user`` : ``ForeignKey(User)``, utilisateur⋅rice qui a adhéré.
|
||||||
* ``date_start`` : ``DateField``, date de début d'adhésion.
|
* ``date_start`` : ``DateField``, date de début d'adhésion.
|
||||||
* ``date_end`` : ``DateField``, date de fin d'adhésion.
|
* ``date_end`` : ``DateField``, date de fin d'adhésion.
|
||||||
* ``fee`` : ``PositiveIntegerField``, montant de la cotisation payée.
|
* ``fee`` : ``PositiveIntegerField``, montant de la cotisation payée.
|
||||||
* ``roles`` : ``ManyToManyField(Role)``, liste des rôles endossés par l'adhérent.
|
* ``roles`` : ``ManyToManyField(Role)``, liste des rôles endossés par l'adhérent⋅e.
|
||||||
|
|
||||||
Rôles
|
Rôles
|
||||||
~~~~~
|
~~~~~
|
||||||
|
|
||||||
Comme indiqué le modèle des adhésions, les adhésions octroient des rôles aux adhérents, qui offrent des permissions
|
Comme indiqué le modèle des adhésions, les adhésions octroient des rôles aux adhérent⋅es, qui offrent des permissions
|
||||||
(cf ``RolesPermissions`` dans la page des permissions). Le modèle ``RolesPermissions`` possède un
|
(cf ``RolesPermissions`` dans la page des permissions). Le modèle ``RolesPermissions`` possède un
|
||||||
``OneToOneField(Role)``, qui implémente les permissions des rôles. Le modèle ``Role`` à proprement parler ne contient
|
``OneToOneField(Role)``, qui implémente les permissions des rôles. Le modèle ``Role`` à proprement parler ne contient
|
||||||
que le champ de son nom (``CharField``).
|
que le champ de son nom (``CharField``).
|
||||||
|
@ -88,7 +88,7 @@ Si le modèle ``MembershipTransaction`` appartient à l'application ``note``, il
|
||||||
Le modèle ``MembershipTransaction`` est une extension du modèle ``Transaction`` (application ``note``) qui est de type
|
Le modèle ``MembershipTransaction`` est une extension du modèle ``Transaction`` (application ``note``) qui est de type
|
||||||
polymorphique, et contient en plus des informations de base de la transaction un champ ``OneToOneField(Membership)``
|
polymorphique, et contient en plus des informations de base de la transaction un champ ``OneToOneField(Membership)``
|
||||||
faisant le lien entre l'adhésion et la transaction liée. Une adhésion club, si elle n'est pas gratuite,
|
faisant le lien entre l'adhésion et la transaction liée. Une adhésion club, si elle n'est pas gratuite,
|
||||||
génère en effet automatiquement une transaction de l'utilisateur vers le club (voir section adhésions).
|
génère en effet automatiquement une transaction de l'utilisateur⋅rice vers le club (voir section adhésions).
|
||||||
|
|
||||||
Graphe
|
Graphe
|
||||||
------
|
------
|
||||||
|
@ -100,28 +100,28 @@ Adhésions
|
||||||
---------
|
---------
|
||||||
|
|
||||||
La Note Kfet offre la possibilité aux clubs de gérer l'adhésion de leurs membres. En plus de réguler les cotisations
|
La Note Kfet offre la possibilité aux clubs de gérer l'adhésion de leurs membres. En plus de réguler les cotisations
|
||||||
des adhérents, des permissions sont octroyées sur la note en fonction des rôles au sein des clubs. Un rôle est une
|
des adhérent⋅es, des permissions sont octroyées sur la note en fonction des rôles au sein des clubs. Un rôle est une
|
||||||
fonction occupée au sein d'un club (Trésorier de club, président de club, GCKfet, Res[pot], respo info, ...).
|
fonction occupée au sein d'un club (Trésorièr⋅e de club, président⋅e de club, GC Kfet, Res[pot], respo info,…).
|
||||||
Une adhésion attribue à un adhérent ses rôles. Les rôles fournissent les permissions. Par exemple, le trésorier d'un
|
Une adhésion attribue à un⋅e adhérent⋅e ses rôles. Les rôles fournissent les permissions. Par exemple, læ trésorièr⋅e d'un
|
||||||
club a le droit de faire des transferts de et vers la note du club, tant que la source reste au-dessus de -50 €.
|
club a le droit de faire des transferts de et vers la note du club, tant que la source reste au-dessus de -50 €.
|
||||||
Une adhésion est considérée comme valide si la date du jour est comprise (au sens large) entre les dates de début et
|
Une adhésion est considérée comme valide si la date du jour est comprise (au sens large) entre les dates de début et
|
||||||
de fin d'adhésion.
|
de fin d'adhésion.
|
||||||
|
|
||||||
On peut ajouter une adhésion à un utilisateur dans un club à tout non adhérent de ce club. La personne en charge
|
On peut ajouter une adhésion à un⋅e utilisateur⋅rice dans un club à tout⋅e non adhérent⋅e de ce club. La personne en charge
|
||||||
d'adhérer quelqu'un choisit l'utilisateur, les rôles au sein du club et la date de début d'adhésion. Cette date de
|
d'adhérer quelqu'un choisit l'utilisateur⋅rice, les rôles au sein du club et la date de début d'adhésion. Cette date de
|
||||||
début d'adhésion doit se situer entre les champs ``club.membership_start`` et ``club.membership_end``,
|
début d'adhésion doit se situer entre les champs ``club.membership_start`` et ``club.membership_end``,
|
||||||
si ces champs sont non nuls. Si ``club.parent_club`` n'est pas nul, l'utilisateur doit être membre de ce club.
|
si ces champs sont non nuls. Si ``club.parent_club`` n'est pas nul, l'utilisateur⋅rice doit être membre de ce club.
|
||||||
Le montant de la cotisation est fixé en fonction du statut normalien de l'utilisateur (``club.membership_fee_paid``
|
Le montant de la cotisation est fixé en fonction du statut normalien de l'utilisateur⋅rice (``club.membership_fee_paid``
|
||||||
centimes pour les élèves et ``club.membership_fee_unpaid`` centimes pour les étudiants). La date de fin est calculée
|
centimes pour les élèves et ``club.membership_fee_unpaid`` centimes pour les étudiant⋅es). La date de fin est calculée
|
||||||
comme ce qui suit :
|
comme ce qui suit :
|
||||||
|
|
||||||
* Si ``club.membership_duration`` est non nul, alors ``date_end`` = ``date_start`` + ``club.membership_duration``
|
* Si ``club.membership_duration`` est non nul, alors ``date_end`` = ``date_start`` + ``club.membership_duration``
|
||||||
* Sinon ``club``, ``date_end`` = ``date_start`` + 424242 jours (suffisant pour tenir au moins une vie)
|
* Sinon ``club``, ``date_end`` = ``date_start`` + 424242 jours (suffisant pour tenir au moins une vie)
|
||||||
* Si ``club.membership_end`` est non nul, alors ``date_end`` = min(``date_end``, ``club.membership_end``)
|
* Si ``club.membership_end`` est non nul, alors ``date_end`` = min(``date_end``, ``club.membership_end``)
|
||||||
|
|
||||||
Si l'utilisateur n'est pas membre du club ``Kfet``, l'adhésion n'est pas possible si le solde disponible sur sa note est
|
Si l'utilisateur⋅rice n'est pas membre du club ``Kfet``, l'adhésion n'est pas possible si le solde disponible sur sa note est
|
||||||
insuffisant. Une fois toute ces contraintes vérifiées, l'adhésion est créée. Une transaction de type
|
insuffisant. Une fois toute ces contraintes vérifiées, l'adhésion est créée. Une transaction de type
|
||||||
``MembershipTransaction`` est automatiquement créée de la note de l'utilisateur vers la note du club, finalisant l'adhésion.
|
``MembershipTransaction`` est automatiquement créée de la note de l'utilisateur⋅rice vers la note du club, finalisant l'adhésion.
|
||||||
|
|
||||||
Réadhésions
|
Réadhésions
|
||||||
~~~~~~~~~~~
|
~~~~~~~~~~~
|
||||||
|
@ -137,7 +137,7 @@ Il est possible de réadhérer si :
|
||||||
* Il n'y a pas encore de réadhésion (pas d'adhésion au même club vérifiant ``new_membership.date_start`` >= ``club.membership_start``)
|
* Il n'y a pas encore de réadhésion (pas d'adhésion au même club vérifiant ``new_membership.date_start`` >= ``club.membership_start``)
|
||||||
|
|
||||||
Un bouton ``Réadhérer`` apparaît dans la liste des adhésions si le droit est permis et si ces contraintes sont vérifiées.
|
Un bouton ``Réadhérer`` apparaît dans la liste des adhésions si le droit est permis et si ces contraintes sont vérifiées.
|
||||||
En réadhérant, une nouvelle adhésion est créée pour l'utilisateur avec les mêmes rôles, commençant le lendemain de la
|
En réadhérant, une nouvelle adhésion est créée pour l'utilisateur⋅rice avec les mêmes rôles, commençant le lendemain de la
|
||||||
date d'expiration de la précédente adhésion. Si on réadhère le 16 août pour une adhésion finissant le 30 septembre,
|
date d'expiration de la précédente adhésion. Si on réadhère le 16 août pour une adhésion finissant le 30 septembre,
|
||||||
la nouvelle adhésion commencera le 1er octobre).
|
la nouvelle adhésion commencera le 1er octobre).
|
||||||
|
|
||||||
|
|
|
@ -7,23 +7,23 @@ Affichage
|
||||||
La page de consommations est principalement une communication entre l'`API <../api>`_ et la page en JavaScript.
|
La page de consommations est principalement une communication entre l'`API <../api>`_ et la page en JavaScript.
|
||||||
Elle est disponible à l'adresse ``/note/consos/``, et l'onglet n'est visible que pour ceux ayant le droit de voir au
|
Elle est disponible à l'adresse ``/note/consos/``, et l'onglet n'est visible que pour ceux ayant le droit de voir au
|
||||||
moins un bouton. L'affichage, comme tout le reste de la page, est géré avec Boostrap 4.
|
moins un bouton. L'affichage, comme tout le reste de la page, est géré avec Boostrap 4.
|
||||||
Les boutons que l'utilisateur a le droit de voir sont triés par catégorie.
|
Les boutons que l'utilisateur⋅rice a le droit de voir sont triés par catégorie.
|
||||||
|
|
||||||
Sélection des consommations
|
Sélection des consommations
|
||||||
---------------------------
|
---------------------------
|
||||||
|
|
||||||
Lorsque l'utilisateur commence à taper un nom de note, un appel à l'API sur la page ``/api/note/alias`` est fait,
|
Lorsque l'utilisateur⋅rice commence à taper un nom de note, un appel à l'API sur la page ``/api/note/alias`` est fait,
|
||||||
récupérant les 20 premiers aliases en accord avec la requête. Quand l'utilisateur survole un alias, un appel à la page
|
récupérant les 20 premiers aliases en accord avec la requête. Quand l'utilisateur⋅rice survole un alias, un appel à la page
|
||||||
``/api/note/note/<NOTE_ID>/`` est fait pour récupérer plus d'infos sur la note telles que le solde, le vrai nom de la
|
``/api/note/note/<NOTE_ID>/`` est fait pour récupérer plus d'infos sur la note telles que le solde, le vrai nom de la
|
||||||
note et la photo, si toutefois l'utilisateur a le droit de voir ceci.
|
note et la photo, si toutefois l'utilisateur⋅rice a le droit de voir ceci.
|
||||||
|
|
||||||
L'utilisateur peut cliquer sur des aliases pour ajouter des émetteurs, et sur des boutons pour ajouter des consommations.
|
L'utilisateur⋅rice peut cliquer sur des aliases pour ajouter des émetteur⋅rices, et sur des boutons pour ajouter des consommations.
|
||||||
Cliquer dans la liste des émetteurs supprime l'élément sélectionné.
|
Cliquer dans la liste des émetteur⋅rices supprime l'élément sélectionné.
|
||||||
|
|
||||||
Il ya deux possibilités pour faire consommer des adhérents :
|
Il y a deux possibilités pour faire consommer des adhérent⋅es :
|
||||||
- En mode **consommation simple** (mode par défaut), les consommations sont débitées dès que émetteurs et consommations
|
- En mode **consommation simple** (mode par défaut), les consommations sont débitées dès que émetteur⋅rices et consommations
|
||||||
sont renseignées.
|
sont renseignées.
|
||||||
- En mode **consommation double**, l'utilisateur doit cliquer sur "Consommer !" pour débiter toutes les consommations.
|
- En mode **consommation double**, l'utilisateur⋅rice doit cliquer sur « **Consommer !** »" pour débiter toutes les consommations.
|
||||||
|
|
||||||
Débit des consommations
|
Débit des consommations
|
||||||
-----------------------
|
-----------------------
|
||||||
|
@ -71,7 +71,7 @@ des types. Il vaut `42` lors de la rédaction de cette documentation, mais pourr
|
||||||
Si une erreur survient lors de la requête (droits insuffisants), un message apparaîtra en haut de page.
|
Si une erreur survient lors de la requête (droits insuffisants), un message apparaîtra en haut de page.
|
||||||
Dans tous les cas, tous les champs sont réinitialisés.
|
Dans tous les cas, tous les champs sont réinitialisés.
|
||||||
|
|
||||||
L'historique et la balance de l'utilisateur sont ensuite mis à jour via jQuery, qui permet de recharger une partie de page Web.
|
L'historique et le solde de l'utilisateur⋅rice sont ensuite mis à jour via jQuery, qui permet de recharger une partie de page Web.
|
||||||
|
|
||||||
Validation/dévalidation des transactions
|
Validation/dévalidation des transactions
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
@ -86,4 +86,4 @@ une requête PATCH est faite à l'API sur l'adresse ``/api/note/transaction/tran
|
||||||
"valid": false
|
"valid": false
|
||||||
}
|
}
|
||||||
|
|
||||||
L'historique et la balance sont ensuite rafraîchis. Si une erreur survient, un message apparaîtra.
|
L'historique et le solde sont ensuite rafraîchis. Si une erreur survient, un message apparaîtra.
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
Application Note
|
Application Note
|
||||||
================
|
================
|
||||||
|
|
||||||
L'application ``note`` gère tout ce qui est en lien avec les flux d'argent et les notes (balances) des utilisateurs.
|
L'application ``note`` gère tout ce qui est en lien avec les flux d'argent et les notes (soldes) des utilisateur⋅rices.
|
||||||
|
|
||||||
La gestion des consommations s'effectue principalement via la page dédiée, dont le fonctionnement est expliqué
|
La gestion des consommations s'effectue principalement via la page dédiée, dont le fonctionnement est expliqué
|
||||||
dans la page `Consommations <consumptions>`_.
|
dans la page `Consommations <consumptions>`_.
|
||||||
|
|
||||||
Le fonctionnnemnent des crédit/débit de note (avec le "monde extérieur" donc avec de l'argent réel) ainsi que les
|
Le fonctionnement des crédit/débit de note (avec le « monde extérieur » donc avec de l'argent réel) ainsi que les
|
||||||
transferts/dons entre notes est détaillé sur la page `Transferts <transactions>`_.
|
transferts/dons entre notes est détaillé sur la page `Transferts <transactions>`_.
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
|
|
|
@ -6,7 +6,7 @@ Affichage
|
||||||
|
|
||||||
L'interface de la page de transferts est semblable à celles des consommations, et l'auto-complétion de note est géré de
|
L'interface de la page de transferts est semblable à celles des consommations, et l'auto-complétion de note est géré de
|
||||||
la même manière. La page se trouve à l'adresse ``/note/transfer/``. La liste des 20 transactions les plus récentes que
|
la même manière. La page se trouve à l'adresse ``/note/transfer/``. La liste des 20 transactions les plus récentes que
|
||||||
l'utilisateur a le droit de voir est également présente.
|
l'utilisateur⋅rice a le droit de voir est également présente.
|
||||||
|
|
||||||
Des boutons ``Don``, ``Transfert``, ``Crédit``, ``Retrait`` sont présents, représentant les différents modes de
|
Des boutons ``Don``, ``Transfert``, ``Crédit``, ``Retrait`` sont présents, représentant les différents modes de
|
||||||
transfert. Pour chaque transfert, un montant et une description sont attendus.
|
transfert. Pour chaque transfert, un montant et une description sont attendus.
|
||||||
|
@ -23,7 +23,7 @@ Onglets Crédit et retrait
|
||||||
Ces onglets ne sont visibles que par ceux qui ont le droit de voir les ``SpecialNote``.
|
Ces onglets ne sont visibles que par ceux qui ont le droit de voir les ``SpecialNote``.
|
||||||
|
|
||||||
Une boîte supplémentaire apparaît, demandant en plus de la note, du montant et de la raison le nom, le prénom et
|
Une boîte supplémentaire apparaît, demandant en plus de la note, du montant et de la raison le nom, le prénom et
|
||||||
la banque de la personne à recharger/retirer. Lorsqu'une note est sélectionnée, les champs "nom" et "prénom" sont
|
la banque de la personne à recharger/retirer. Lorsqu'une note est sélectionnée, les champs « nom » et « prénom » sont
|
||||||
remplis automatiquement. Par ailleurs, seule une note peut être choisie.
|
remplis automatiquement. Par ailleurs, seule une note peut être choisie.
|
||||||
|
|
||||||
Transfert
|
Transfert
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
Droits
|
Droits
|
||||||
======
|
======
|
||||||
|
|
||||||
Le système de droit par défault de django n'est pas suffisament granulaire pour les besoins de la NoteKfet2020.
|
Le système de droit par défaut de Django n'est pas suffisamment granulaire pour les besoins de la Note Kfet 2020.
|
||||||
Un système custom a donc été développé.
|
Un système personnalisé a donc été développé.
|
||||||
|
|
||||||
Il permet la création de Permission, qui autorise ou non a faire une action précise sur un ou des objets
|
Il permet la création de Permission, qui autorise ou non a faire une action précise sur un ou des objets
|
||||||
de la base de données.
|
de la base de données.
|
||||||
|
@ -22,12 +22,12 @@ Une permission est un Model Django dont les principaux attributs sont :
|
||||||
* ``query`` : Requête sur la cible, encodé en JSON, traduit en un Q object (cf `Query <#compilation-de-la-query>`_)
|
* ``query`` : Requête sur la cible, encodé en JSON, traduit en un Q object (cf `Query <#compilation-de-la-query>`_)
|
||||||
* ``field`` : le champ cible qui pourra être modifié. (tous les champs si vide)
|
* ``field`` : le champ cible qui pourra être modifié. (tous les champs si vide)
|
||||||
|
|
||||||
Pour savoir si un utilisateur a le droit sur un modèle ou non, la requête est compilée (voir ci-dessous) en un filtre
|
Pour savoir si un⋅e utilisateur⋅rice a le droit sur un modèle ou non, la requête est compilée (voir ci-dessous) en un filtre
|
||||||
de requête dans la base de données, un objet de la classe ``Q`` (En SQL l'objet Q s'interprete comme tout ce qui suit
|
de requête dans la base de données, un objet de la classe ``Q`` (En SQL l'objet Q s'interprète comme tout ce qui suit
|
||||||
un ``WHERE ...`` Ils peuvent être combiné à l'aide d'opérateurs logiques. Plus d'information sur les Q object dans la
|
un ``WHERE ...`` Ils peuvent être combiné à l'aide d'opérateurs logiques. Plus d'information sur les Q object dans la
|
||||||
`documentation officielle <https://docs.djangoproject.com/fr/2.2/topics/db/queries/#complex-lookups-with-q-objects>`_.
|
`documentation officielle <https://docs.djangoproject.com/fr/2.2/topics/db/queries/#complex-lookups-with-q-objects>`_.
|
||||||
|
|
||||||
Ce Q object sera donc utilisé pour savoir si l'instance que l'on veux modifier est concernée par notre permission.
|
Ce Q object sera donc utilisé pour savoir si l'instance que l'on veut modifier est concernée par notre permission.
|
||||||
|
|
||||||
Exception faite sur l'ajout d'objets : l'objet n'existant pas encore en base de données, il est ajouté puis supprimé
|
Exception faite sur l'ajout d'objets : l'objet n'existant pas encore en base de données, il est ajouté puis supprimé
|
||||||
à la volée, en prenant soin de désactiver les signaux.
|
à la volée, en prenant soin de désactiver les signaux.
|
||||||
|
@ -36,7 +36,7 @@ Compilation de la query
|
||||||
-----------------------
|
-----------------------
|
||||||
|
|
||||||
La query est enregistrée sous un format JSON, puis est traduite en requête ``Q`` récursivement en appliquant certains paramètres.
|
La query est enregistrée sous un format JSON, puis est traduite en requête ``Q`` récursivement en appliquant certains paramètres.
|
||||||
Le fonctionnemente de base des permission peux être décris avec les differents opérations :
|
Le fonctionnemente de base des permission peux être décris avec les différents opérations :
|
||||||
|
|
||||||
+----------------+-----------------------------+-------------------------------------+
|
+----------------+-----------------------------+-------------------------------------+
|
||||||
| opérations | JSON | Q object |
|
| opérations | JSON | Q object |
|
||||||
|
@ -64,7 +64,7 @@ Exemples
|
||||||
|
|
||||||
{"is_superuser": true}
|
{"is_superuser": true}
|
||||||
|
|
||||||
| si l'utilisateur cible est un super utilisateur.
|
| si l'utilisateur⋅rice cible est un⋅e super utilisateur⋅rice.
|
||||||
|
|
||||||
* sur le model ``Note`` :
|
* sur le model ``Note`` :
|
||||||
|
|
||||||
|
@ -74,7 +74,7 @@ Exemples
|
||||||
["user","note", "pk"]
|
["user","note", "pk"]
|
||||||
}
|
}
|
||||||
|
|
||||||
| si l'identifiant de la note cible est l'identifiant de l'utilisateur dont on regarde la permission.
|
| si l'identifiant de la note cible est l'identifiant de l'utilisateur⋅rice dont on regarde la permission.
|
||||||
|
|
||||||
* sur le model ``Transaction``:
|
* sur le model ``Transaction``:
|
||||||
|
|
||||||
|
@ -87,7 +87,7 @@ Exemples
|
||||||
["user", "note", "balance"]}
|
["user", "note", "balance"]}
|
||||||
]
|
]
|
||||||
|
|
||||||
| si la source est la note de l'utilisateur et si le montant est inférieur à son solde.
|
| si la source est la note de l'utilisateur⋅rice et si le montant est inférieur à son solde.
|
||||||
|
|
||||||
* Sur le model ``Alias``
|
* Sur le model ``Alias``
|
||||||
|
|
||||||
|
@ -106,7 +106,7 @@ Exemples
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
||||||
| si l'alias appartient à une note de club ou s'il appartient à la note d'un utilisateur membre du club Kfet.
|
| si l'alias appartient à une note de club ou s'il appartient à la note d'un⋅e utilisateur⋅rice membre du club Kfet.
|
||||||
|
|
||||||
* sur le model ``Transaction``
|
* sur le model ``Transaction``
|
||||||
|
|
||||||
|
@ -130,19 +130,19 @@ Exemples
|
||||||
Masques de permissions
|
Masques de permissions
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
Chaque permission est associée à un masque. À la connexion, l'utilisateur choisit le masque de droits avec lequel il
|
Chaque permission est associée à un masque. À la connexion, l'utilisateur⋅rice choisit le masque de droits avec lequel iel
|
||||||
souhaite se connecter. Les masques sont ordonnés totalement, et l'utilisateur aura effectivement une permission s'il est
|
souhaite se connecter. Les masques sont ordonnés totalement, et l'utilisateur⋅rice aura effectivement une permission si iel est
|
||||||
en droit d'avoir la permission et si son masque est suffisamment haut.
|
en droit d'avoir la permission et si son masque est suffisamment haut.
|
||||||
|
|
||||||
Par exemple, si la permission de voir toutes les transactions est associée au masque "Droits note uniquement",
|
Par exemple, si la permission de voir toutes les transactions est associée au masque « Droits note uniquement »,
|
||||||
se connecter avec le masque "Droits basiques" n'octroiera pas cette permission tandis que le masque "Tous mes droits" oui.
|
se connecter avec le masque « Droits basiques » n'octroiera pas cette permission tandis que le masque « Tous mes droits » oui.
|
||||||
|
|
||||||
Signaux
|
Signaux
|
||||||
-------
|
-------
|
||||||
|
|
||||||
À chaque fois qu'un modèle est modifié, ajouté ou supprimé, les droits sont contrôlés. Si les droits ne sont pas
|
À chaque fois qu'un modèle est modifié, ajouté ou supprimé, les droits sont contrôlés. Si les droits ne sont pas
|
||||||
suffisants, une erreur est lancée. Pour ce qui est de la modification, on ne contrôle que les champs réellement
|
suffisants, une erreur est lancée. Pour ce qui est de la modification, on ne contrôle que les champs réellement
|
||||||
modifiés en comparant l'ancienne et la nouvele instance.
|
modifiés en comparant l'ancienne et la nouvelle instance.
|
||||||
|
|
||||||
Graphe des modèles
|
Graphe des modèles
|
||||||
------------------
|
------------------
|
||||||
|
|
|
@ -4,7 +4,7 @@ Inscriptions
|
||||||
L'inscription a la note se fait via une application dédiée, sans toutefois avoir de modèle en base de données.
|
L'inscription a la note se fait via une application dédiée, sans toutefois avoir de modèle en base de données.
|
||||||
|
|
||||||
Un formulaire d'inscription est disponible sur la page ``/registration/signup``, accessible depuis n'importe qui,
|
Un formulaire d'inscription est disponible sur la page ``/registration/signup``, accessible depuis n'importe qui,
|
||||||
authentifié ou non. Les informations suivantes sont demandées :
|
authentifié⋅e ou non. Les informations suivantes sont demandées :
|
||||||
|
|
||||||
* Prénom
|
* Prénom
|
||||||
* Nom de famille
|
* Nom de famille
|
||||||
|
@ -15,7 +15,7 @@ authentifié ou non. Les informations suivantes sont demandées :
|
||||||
* Département d'études
|
* Département d'études
|
||||||
* Promotion, année d'entrée à l'ENS
|
* Promotion, année d'entrée à l'ENS
|
||||||
* Adresse (optionnel)
|
* Adresse (optionnel)
|
||||||
* Payé (si la personne perçoit un salaire)
|
* Payé⋅e (si la personne perçoit un salaire)
|
||||||
|
|
||||||
Le mot de passe doit vérifier des contraintes de longueur, de complexité et d'éloignement des autres informations
|
Le mot de passe doit vérifier des contraintes de longueur, de complexité et d'éloignement des autres informations
|
||||||
personnelles.
|
personnelles.
|
||||||
|
@ -34,28 +34,28 @@ le compte sera enfin actif.
|
||||||
Pour récapituler : compte actif = adresse e-mail validée + inscription validée par le BDE.
|
Pour récapituler : compte actif = adresse e-mail validée + inscription validée par le BDE.
|
||||||
|
|
||||||
Lors de la validation de l'inscription, le BDE peut (et doit même) faire un crédit initial sur la future note de
|
Lors de la validation de l'inscription, le BDE peut (et doit même) faire un crédit initial sur la future note de
|
||||||
l'utilisateur. Il peut spécifier le type de crédit (carte bancaire/espèces/chèque/virement bancaire), le prénom,
|
l'utilisateur⋅rice. Il peut spécifier le type de crédit (carte bancaire/espèces/chèque/virement bancaire), le prénom,
|
||||||
le nom et la banque comme un crédit normal. Cependant, il peut aussi cocher une case "Société générale", si le nouveau
|
le nom et la banque comme un crédit normal. Cependant, il peut aussi cocher une case "Société générale", si le nouveau
|
||||||
membre indique avoir ouvert un compte à la Société générale via le partenariat Société générale - BDE de
|
membre indique avoir ouvert un compte à la Société générale via le partenariat Société générale - BDE de
|
||||||
l'ÉNS Paris-Saclay. Dans ce cas, tous les champs sont grisés.
|
l'ÉNS Paris-Saclay. Dans ce cas, tous les champs sont grisés.
|
||||||
|
|
||||||
Une fois l'inscription validée, détail de ce qu'il se passe :
|
Une fois l'inscription validée, détail de ce qu'il se passe :
|
||||||
|
|
||||||
* Si crédit de la socitété générale, on mémorise que le fait que la personne ait demandé ce crédit (voir
|
* Si crédit de la société générale, on mémorise que le fait que la personne ait demandé ce crédit (voir
|
||||||
`Trésorerie <treasury>`_ section crédits de la société générale). Nécessairement, le club Kfet doit être rejoint.
|
`Trésorerie <treasury>`_ section crédits de la société générale). Nécessairement, le club Kfet doit être rejoint.
|
||||||
* Sinon, on crédite la note du montant demandé par le nouveau membre (avec comme description "Crédit TYPE (Inscription)"
|
* Sinon, on crédite la note du montant demandé par læ nouvelleau membre (avec comme description "Crédit TYPE (Inscription)"
|
||||||
où TYPE est le type de crédit), après avoir vérifié que le crédit est suffisant (on n'ouvre pas une note négative)
|
où TYPE est le type de crédit), après avoir vérifié que le crédit est suffisant (on n'ouvre pas une note négative)
|
||||||
* On adhère la personne au BDE, l'adhésion commence aujourd'hui. Il dispose d'un unique rôle : "Adhérent BDE",
|
* On adhère la personne au BDE, l'adhésion commence aujourd'hui. Iel dispose d'un unique rôle : « Adhérent⋅e BDE »,
|
||||||
lui octroyant un faible nombre de permissions de base, telles que la visualisation de son compte.
|
lui octroyant un faible nombre de permissions de base, telles que la visualisation de son compte.
|
||||||
* On adhère la personne au club Kfet si cela est demandé, l'adhésion commence aujourd'hui. Il dispose d'un unique rôle :
|
* On adhère la personne au club Kfet si cela est demandé, l'adhésion commence aujourd'hui. Iel dispose d'un unique rôle :
|
||||||
"Adhérent Kfet", lui octroyant un nombre un peu plus conséquent de permissions basiques, telles que la possibilité de
|
« Adhérent⋅e Kfet » , lui octroyant un nombre un peu plus conséquent de permissions basiques, telles que la possibilité de
|
||||||
faire des transactions, d'accéder aux activités, au WEI, ...
|
faire des transactions, d'accéder aux activités, au WEI,…
|
||||||
* Si le nouveau membre a indiqué avoir ouvert un compte à la société générale, alors les transactions sont invalidées,
|
* Si læ nouvelleau membre a indiqué avoir ouvert un compte à la société générale, alors les transactions sont invalidées,
|
||||||
la note n'est pas débitée (commence alors à 0 €).
|
la note n'est pas débitée (commence alors à 0 €).
|
||||||
|
|
||||||
Par ailleurs, le BDE peut supprimer la demande d'inscription sans problème via un bouton dédié. Cette opération
|
Par ailleurs, le BDE peut supprimer la demande d'inscription sans problème via un bouton dédié. Cette opération
|
||||||
n'est pas réversible.
|
n'est pas réversible.
|
||||||
|
|
||||||
L'utilisateur a enfin accès a sa note et peut faire des bêtises :)
|
L'utilisateur⋅rice a enfin accès a sa note et peut faire des bêtises :)
|
||||||
|
|
||||||
L'inscription au BDE et à la Kfet est indépendante de l'inscription au WEI. Voir `WEI <wei>`_ pour l'inscription WEI.
|
L'inscription au BDE et à la Kfet est indépendante de l'inscription au WEI. Voir `WEI <wei>`_ pour l'inscription WEI.
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
Application Trésorerie
|
Application Trésorerie
|
||||||
======================
|
======================
|
||||||
|
|
||||||
L'application de Trésorerie facilite la vie des trésorier, et sert d'interface de création de facture.
|
L'application de Trésorerie facilite la vie des trésorièr⋅es, et sert d'interface de création de facture.
|
||||||
Elle permet également le suivi des remises de chèques reçus par le BDE et des crédits de la Société générale.
|
Elle permet également le suivi des remises de chèques reçus par le BDE et des crédits de la Société générale.
|
||||||
|
|
||||||
Factures
|
Factures
|
||||||
|
@ -90,7 +90,7 @@ présent à l'adresse suivante :
|
||||||
|
|
||||||
On le remplit avec les données de la facture et les données du BDE, hard-codées. On copie le template rempli dans un
|
On le remplit avec les données de la facture et les données du BDE, hard-codées. On copie le template rempli dans un
|
||||||
ficher tex dans un dossier temporaire. On fait ensuite 2 appels à ``pdflatex`` pour générer la facture au format PDF.
|
ficher tex dans un dossier temporaire. On fait ensuite 2 appels à ``pdflatex`` pour générer la facture au format PDF.
|
||||||
Les deux appels sont nécessaires, il y a besoin d'un double rendu. Ensuite, le PDF est envoyé à l'utilisateur et on
|
Les deux appels sont nécessaires, il y a besoin d'un double rendu. Ensuite, le PDF est envoyé à l'utilisateur⋅rice et on
|
||||||
supprime les données temporaires.
|
supprime les données temporaires.
|
||||||
|
|
||||||
On remarque que les PDF sont générés à la volée et ne sont pas sauvegardés. Niveau performances, cela prend du temps
|
On remarque que les PDF sont générés à la volée et ne sont pas sauvegardés. Niveau performances, cela prend du temps
|
||||||
|
@ -155,7 +155,7 @@ Relations
|
||||||
~~~~~~~~~
|
~~~~~~~~~
|
||||||
|
|
||||||
* Toute transaction qui n'est pas attachée à une remise d'un bon type peut être attachée à une remise. Cela se passe
|
* Toute transaction qui n'est pas attachée à une remise d'un bon type peut être attachée à une remise. Cela se passe
|
||||||
par le biais d'un formulaire, où le trésorier peut vérifier et corriger au besoin nom, prénom, banque émettrice et montant.
|
par le biais d'un formulaire, où læ trésorièr⋅e peut vérifier et corriger au besoin nom, prénom, banque émettrice et montant.
|
||||||
|
|
||||||
* Toute transaction attachée à une remise encore ouverte peut être retirée.
|
* Toute transaction attachée à une remise encore ouverte peut être retirée.
|
||||||
* Pour clore une remise, il faut au moins 1 transaction associée.
|
* Pour clore une remise, il faut au moins 1 transaction associée.
|
||||||
|
@ -174,39 +174,39 @@ Modèle
|
||||||
|
|
||||||
Cette sous-application dispose d'un unique modèle "SogeCredit" avec les champs suivant :
|
Cette sous-application dispose d'un unique modèle "SogeCredit" avec les champs suivant :
|
||||||
|
|
||||||
* ``user`` : ``OneToOneField`` vers ``User``, utilisateur associé à ce crédit (relation ``OneToOne`` car chaque
|
* ``user`` : ``OneToOneField`` vers ``User``, utilisateur⋅rice associé à ce crédit (relation ``OneToOne`` car chaque
|
||||||
utilisateur ne peut bénéficier qu'une seule fois d'un crédit de la Société générale)
|
utilisateur⋅rice ne peut bénéficier qu'une seule fois d'un crédit de la Société générale)
|
||||||
* ``transactions`` : ``ManyToManyField`` vers ``MembershipTransaction``, liste des transactions d'adhésion associées
|
* ``transactions`` : ``ManyToManyField`` vers ``MembershipTransaction``, liste des transactions d'adhésion associées
|
||||||
à ce crédit, généralement adhésion BDE+Kfet+WEI même si cela n'est pas restreint
|
à ce crédit, généralement adhésion BDE+Kfet+WEI même si cela n'est pas restreint
|
||||||
* ``credit_transaction`` : ``OneToOneField`` vers ``SpecialTransaction``, peut être nulle, transaction de crédit de la
|
* ``credit_transaction`` : ``OneToOneField`` vers ``SpecialTransaction``, peut être nulle, transaction de crédit de la
|
||||||
Société générale vers la note de l'utilisateur si celui-ci a été validé. C'est d'ailleurs le témoin
|
Société générale vers la note de l'utilisateur⋅rice si celui-ci a été validé. C'est d'ailleurs le témoin
|
||||||
de validation du crédit.
|
de validation du crédit.
|
||||||
|
|
||||||
On sait qu'un utilisateur a déjà demandé un crédit de la Société générale s'il existe un crédit associé à cet
|
On sait qu'un⋅e utilisateur⋅rice a déjà demandé un crédit de la Société générale s'il existe un crédit associé à cet⋅te
|
||||||
utilisateur avec une transaction associée. Par ailleurs, le modèle ``Profile`` contient une propriété ``soge`` qui
|
utilisateur⋅rice avec une transaction associée. Par ailleurs, le modèle ``Profile`` contient une propriété ``soge`` qui
|
||||||
traduit exactement ceci, et qui vaut ``False`` si jamais l'application Trésorerie n'est pas chargée.
|
traduit exactement ceci, et qui vaut ``False`` si jamais l'application Trésorerie n'est pas chargée.
|
||||||
|
|
||||||
Si jamais l'utilisateur n'a pas encore demandé de crédit de la Société générale (ou que celui-ci n'est pas encore validé),
|
Si jamais l'utilisateur⋅rice n'a pas encore demandé de crédit de la Société générale (ou que celui-ci n'est pas encore validé),
|
||||||
l'utilisateur peut demander un tel crédit lors de son adhésion BDE, de sa réadhésion BDE ou de son inscription au WEI.
|
l'utilisateur⋅rice peut demander un tel crédit lors de son adhésion BDE, de sa réadhésion BDE ou de son inscription au WEI.
|
||||||
Dans les deux premiers cas, il est invité à jumeler avec une nouvelle adhésion Kfet (merci de d'abord se réadhérer au
|
Dans les deux premiers cas, iel est invité⋅e à jumeler avec une nouvelle adhésion Kfet (merci de d'abord se réadhérer au
|
||||||
BDE avant la Kfet dans ce cas).
|
BDE avant la Kfet dans ce cas).
|
||||||
|
|
||||||
Lorsqu'une telle demande est faite, l'adhésion est créée avec une transaction d'adhésion invalide. Cela implique que
|
Lorsqu'une telle demande est faite, l'adhésion est créée avec une transaction d'adhésion invalide. Cela implique que
|
||||||
la note source n'est pas débitée et la note destination n'est pas créditée.
|
la note source n'est pas débitée et la note destination n'est pas créditée.
|
||||||
|
|
||||||
Sur son interface, le trésorier peut récupérer les crédits de Société générale invalides. Deux options s'offrent à lui :
|
Sur son interface, læ trésorièr⋅e peut récupérer les crédits de Société générale invalides. Deux options s'offrent à ellui :
|
||||||
|
|
||||||
* Supprimer la demande. Dans ce cas, les transactions vont être validées, la note de l'utilisateur sera débité, les
|
* Supprimer la demande. Dans ce cas, les transactions vont être validées, la note de l'utilisateur⋅rice sera débité, les
|
||||||
clubs seront crédités. Puisque la demande sera supprimée, l'utilisateur pourra à nouveau à l'avenir déclarer avoir
|
clubs seront crédités. Puisque la demande sera supprimée, l'utilisateur⋅rice pourra à nouveau à l'avenir déclarer avoir
|
||||||
ouvert un compte à la Société générale. Cette option est utile dans le cas où l'utilisateur est un boulet (ou pas,
|
ouvert un compte à la Société générale. Cette option est utile dans le cas où l'utilisateur⋅rice est un boulet (ou pas,
|
||||||
pour d'autres raisons) et a déclaré vouloir ouvrir un compte à la Société générale sans ne rien faire.
|
pour d'autres raisons) et a déclaré vouloir ouvrir un compte à la Société générale sans ne rien faire.
|
||||||
Cette action est irréversible, et n'est pas possible si la note de l'utilisateur n'a pas un solde suffisant.
|
Cette action est irréversible, et n'est pas possible si la note de l'utilisateur⋅rice n'a pas un solde suffisant.
|
||||||
|
|
||||||
* Valider la demande. Dans ce cas, un crédit de la note "Virements bancaires" vers la note de l'utilisateur sera créé,
|
* Valider la demande. Dans ce cas, un crédit de la note "Virements bancaires" vers la note de l'utilisateur⋅rice sera créé,
|
||||||
la transaction sera liée à la demande via le champ ``credit_note`` (et donc la demande déclarée valide), et toutes les
|
la transaction sera liée à la demande via le champ ``credit_note`` (et donc la demande déclarée valide), et toutes les
|
||||||
transactions d'adhésion seront déclarées valides.
|
transactions d'adhésion seront déclarées valides.
|
||||||
|
|
||||||
* Demander à un respo info s'il y a un problème pour le régler avant de faire des bêtises. Je l'admets, ça fait trois options.
|
* Demander à un⋅e respo info s'il y a un problème pour le régler avant de faire des bêtises. Je l'admets, ça fait trois options.
|
||||||
|
|
||||||
La validité d'une transaction d'adhésion n'a aucune influence sur l'adhésion elle-même. Toutefois, cela se remarque rapidement ...
|
La validité d'une transaction d'adhésion n'a aucune influence sur l'adhésion elle-même. Toutefois, cela se remarque rapidement ...
|
||||||
|
|
||||||
|
|
|
@ -19,14 +19,14 @@ Champs hérités de ``Club`` de l'application ``member`` :
|
||||||
|
|
||||||
* ``parent_club`` : ``ForeignKey(Club)``. Ce champ vaut toujours ``Kfet`` dans le cas d'un WEI : on doit être membre du
|
* ``parent_club`` : ``ForeignKey(Club)``. Ce champ vaut toujours ``Kfet`` dans le cas d'un WEI : on doit être membre du
|
||||||
club Kfet pour participer au WEI.
|
club Kfet pour participer au WEI.
|
||||||
* ``email`` : ``EmailField``, adresse e-mail sur laquelle contacter les gérants du WEI.
|
* ``email`` : ``EmailField``, adresse e-mail sur laquelle contacter les gérant⋅es du WEI.
|
||||||
* ``membership_start`` : ``DateField``, date à partir de laquelle il est possible de s'inscrire au WEI.
|
* ``membership_start`` : ``DateField``, date à partir de laquelle il est possible de s'inscrire au WEI.
|
||||||
* ``membership_end`` : ``DateField``, date de fin d'adhésion possible au WEI.
|
* ``membership_end`` : ``DateField``, date de fin d'adhésion possible au WEI.
|
||||||
* ``membership_duration`` : ``PositiveIntegerField``, inutilisé dans le cas d'un WEI, vaut ``None``.
|
* ``membership_duration`` : ``PositiveIntegerField``, inutilisé dans le cas d'un WEI, vaut ``None``.
|
||||||
* ``membership_fee_paid`` : ``PositiveIntegerField``, montant de la cotisation (en centimes) pour qu'un élève normalien
|
* ``membership_fee_paid`` : ``PositiveIntegerField``, montant de la cotisation (en centimes) pour qu'un⋅e élève normalien⋅ne
|
||||||
(donc rémunéré) puisse adhérer.
|
(donc rémunéré⋅e) puisse adhérer.
|
||||||
* ``membership_fee_unpaid`` : ``PositiveIntegerField``, montant de la cotisation (en centimes) pour qu'un étudiant
|
* ``membership_fee_unpaid`` : ``PositiveIntegerField``, montant de la cotisation (en centimes) pour qu'un⋅e étudiant⋅e
|
||||||
normalien (donc non rémunéré) puisse adhérer.
|
normalien⋅ne (donc non rémunéré⋅e) puisse adhérer.
|
||||||
* ``name`` : ``CharField``, nom du WEI.
|
* ``name`` : ``CharField``, nom du WEI.
|
||||||
* ``require_memberships`` : ``BooleanField``, vaut toujours ``True`` pour le WEI.
|
* ``require_memberships`` : ``BooleanField``, vaut toujours ``True`` pour le WEI.
|
||||||
|
|
||||||
|
@ -65,27 +65,27 @@ que de dissocier les rôles propres au WEI des rôles s'appliquant pour n'import
|
||||||
WEIRegistration
|
WEIRegistration
|
||||||
~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Inscription au WEI, contenant les informations avant validation. Ce modèle est créé dès lors que quelqu'un se pré-inscrit au WEI.
|
Inscription au WEI, contenant les informations avant validation. Ce modèle est créé dès lors que quelqu'un⋅e se pré-inscrit au WEI.
|
||||||
|
|
||||||
* ``user`` : ``ForeignKey(User)``, utilisateur qui s'est pré-inscrit. Ce champ est unique avec ``wei``.
|
* ``user`` : ``ForeignKey(User)``, utilisateur⋅rice qui s'est pré-inscrit⋅e. Ce champ est unique avec ``wei``.
|
||||||
* ``wei`` : ``ForeignKey(WEIClub)``, le WEI auquel l'utilisateur s'est pré-inscrit. Ce champ est unique avec ``user``.
|
* ``wei`` : ``ForeignKey(WEIClub)``, le WEI auquel l'utilisateur⋅rice s'est pré-inscrit⋅e. Ce champ est unique avec ``user``.
|
||||||
* ``soge_credit`` : ``BooleanField``, indique si l'utilisateur a déclaré vouloir ouvrir un compte à la Société générale.
|
* ``soge_credit`` : ``BooleanField``, indique si l'utilisateur⋅rice a déclaré vouloir ouvrir un compte à la Société générale.
|
||||||
* ``caution_check`` : ``BooleanField``, indique si l'utilisateur (en 2ème année ou plus) a bien remis son chèque de
|
* ``caution_check`` : ``BooleanField``, indique si l'utilisateur⋅rice (en 2ème année ou plus) a bien remis son chèque de
|
||||||
caution auprès de la trésorerie.
|
caution auprès de la trésorerie.
|
||||||
* ``birth_date`` : ``DateField``, date de naissance de l'utilisateur.
|
* ``birth_date`` : ``DateField``, date de naissance de l'utilisateur⋅rice.
|
||||||
* ``gender`` : ``CharField`` parmi ``male`` (Homme), ``female`` (Femme), ``non binary`` (Non binaire), genre de la personne.
|
* ``gender`` : ``CharField`` parmi ``male`` (Homme), ``female`` (Femme), ``non binary`` (Non binaire), genre de la personne.
|
||||||
* ``health_issues`` : ``TextField``, problèmes de santé déclarés par l'utilisateur.
|
* ``health_issues`` : ``TextField``, problèmes de santé déclarés par l'utilisateur⋅rice.
|
||||||
* ``emergency_contact_name`` : ``CharField``, nom du contact en cas d'urgence.
|
* ``emergency_contact_name`` : ``CharField``, nom du contact en cas d'urgence.
|
||||||
* ``emergency_contact_phone`` : ``CharField``, numéro de téléphone du contact en cas d'urgence.
|
* ``emergency_contact_phone`` : ``CharField``, numéro de téléphone du contact en cas d'urgence.
|
||||||
* ``ml_events_registration`` : ``BooleanField``, déclare si l'utilisateur veut s'inscrire à la liste de diffusion des
|
* ``ml_events_registration`` : ``BooleanField``, déclare si l'utilisateur⋅rice veut s'inscrire à la liste de diffusion des
|
||||||
événements du BDE (1A uniquement)
|
événements du BDE (1A uniquement)
|
||||||
* ``ml_art_registration`` : ``BooleanField``, déclare si l'utilisateur veut s'inscrire à la liste de diffusion des
|
* ``ml_art_registration`` : ``BooleanField``, déclare si l'utilisateur⋅rice veut s'inscrire à la liste de diffusion des
|
||||||
actualités du BDA (1A uniquement)
|
actualités du BDA (1A uniquement)
|
||||||
* ``ml_sport_registration`` : ``BooleanField``, déclare si l'utilisateur veut s'inscrire à la liste de diffusion des
|
* ``ml_sport_registration`` : ``BooleanField``, déclare si l'utilisateur⋅rice veut s'inscrire à la liste de diffusion des
|
||||||
actualités du BDS (1A uniquement)
|
actualités du BDS (1A uniquement)
|
||||||
* ``first_year`` : ``BooleanField``, indique si l'inscription est d'un 1A ou non. Non modifiable par n'importe qui.
|
* ``first_year`` : ``BooleanField``, indique si l'inscription est d'un⋅e 1A ou non. Non modifiable par n'importe qui.
|
||||||
* ``information_json`` : ``TextField`` non modifiable manuellement par n'importe qui stockant les informations du
|
* ``information_json`` : ``TextField`` non modifiable manuellement par n'importe qui stockant les informations du
|
||||||
questionnaire d'inscription au WEI pour les 1A, et stocke les demandes faites par un 2A+ concerant bus, équipes et rôles.
|
questionnaire d'inscription au WEI pour les 1A, et stocke les demandes faites par un⋅e 2A+ concernant bus, équipes et rôles.
|
||||||
On utilise un ``TextField`` contenant des données au format JSON pour permettre de la modularité au fil des années,
|
On utilise un ``TextField`` contenant des données au format JSON pour permettre de la modularité au fil des années,
|
||||||
sans avoir à tout casser à chaque fois.
|
sans avoir à tout casser à chaque fois.
|
||||||
|
|
||||||
|
@ -94,19 +94,19 @@ WEIMembership
|
||||||
|
|
||||||
Ce modèle hérite de ``Membership`` et contient les informations d'une adhésion au WEI.
|
Ce modèle hérite de ``Membership`` et contient les informations d'une adhésion au WEI.
|
||||||
|
|
||||||
* ``bus`` : ``ForeignKey(Bus)``, bus dans lequel se trouve l'utilisateur.
|
* ``bus`` : ``ForeignKey(Bus)``, bus dans lequel se trouve l'utilisateur⋅rice.
|
||||||
* ``team`` : ``ForeignKey(BusTeam)`` pouvant être nulle (pour les chefs de bus et électrons libres), équipe dans laquelle
|
* ``team`` : ``ForeignKey(BusTeam)`` pouvant être nulle (pour les chefs de bus et électrons libres), équipe dans laquelle
|
||||||
se trouve l'utilisateur.
|
se trouve l'utilisateur⋅rice.
|
||||||
* ``registration`` : ``OneToOneField(WEIRegistration)``, informations de la pré-inscription.
|
* ``registration`` : ``OneToOneField(WEIRegistration)``, informations de la pré-inscription.
|
||||||
|
|
||||||
Champs hérités du modèle ``Membership`` :
|
Champs hérités du modèle ``Membership`` :
|
||||||
|
|
||||||
* ``club`` : ``ForeignKey(Club)``, club lié à l'adhésion. Doit être un ``WEIClub``.
|
* ``club`` : ``ForeignKey(Club)``, club lié à l'adhésion. Doit être un ``WEIClub``.
|
||||||
* ``user`` : ``ForeignKey(User)``, utilisateur adhéré.
|
* ``user`` : ``ForeignKey(User)``, utilisateur⋅rice qui a adhéré.
|
||||||
* ``date_start`` : ``DateField``, date de début d'adhésion.
|
* ``date_start`` : ``DateField``, date de début d'adhésion.
|
||||||
* ``date_end`` : ``DateField``, date de fin d'adhésion.
|
* ``date_end`` : ``DateField``, date de fin d'adhésion.
|
||||||
* ``fee`` : ``PositiveIntegerField``, montant de la cotisation payée.
|
* ``fee`` : ``PositiveIntegerField``, montant de la cotisation payée.
|
||||||
* ``roles`` : ``ManyToManyField(Role)``, liste des rôles endossés par l'adhérent. Les rôles doivent être des ``WEIRole``.
|
* ``roles`` : ``ManyToManyField(Role)``, liste des rôles endossés par l'adhérent⋅e. Les rôles doivent être des ``WEIRole``.
|
||||||
|
|
||||||
Graphe des modèles
|
Graphe des modèles
|
||||||
~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~
|
||||||
|
@ -123,32 +123,32 @@ Fonctionnement
|
||||||
Création d'un WEI
|
Création d'un WEI
|
||||||
~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Seul un respo info peut créer un WEI. Pour cela, se rendre dans l'onglet WEI, puis "Liste des WEI" et enfin
|
Seul un⋅e respo info peut créer un WEI. Pour cela, se rendre dans l'onglet WEI, puis « Liste des WEI » et enfin
|
||||||
"Créer un WEI". Diverses informations sont demandées, comme le nom du WEI, l'adresse mail de contact, l'année du WEI
|
« Créer un WEI ». Diverses informations sont demandées, comme le nom du WEI, l'adresse mail de contact, l'année du WEI
|
||||||
(doit être unique), les dates de début et de fin, et les dates pendant lesquelles les utilisateurs peuvent s'inscrire.
|
(doit être unique), les dates de début et de fin, et les dates pendant lesquelles les utilisateurs peuvent s'inscrire.
|
||||||
|
|
||||||
Don des droits à un GC WEI
|
Don des droits à un GC WEI
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Le GC WEI peut gérer tout ce qui a un rapport avec le WEI. Il ne peut cependant pas créer le WEI, ce privilège est
|
Læ GC WEI peut gérer tout ce qui a un rapport avec le WEI. Iel ne peut cependant pas créer le WEI, ce privilège est
|
||||||
réservé au respo info. Pour avoir ses droits, le GC WEI doit s'inscrire au WEI avec le rôle GC WEI, et donc payer
|
réservé aux respos info. Pour avoir ses droits, læ GC WEI doit s'inscrire au WEI avec le rôle GC WEI, et donc payer
|
||||||
en premier sa cotisation. C'est donc au respo info de créer l'adhésion du GC WEI. Voir ci-dessous pour l'inscription au WEI.
|
en premièr⋅e sa cotisation. C'est donc aux respos info de créer l'adhésion du GC WEI. Voir ci-dessous pour l'inscription au WEI.
|
||||||
|
|
||||||
S'inscrire au WEI
|
S'inscrire au WEI
|
||||||
~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
N'importe quel utilisateur peut s'auto-inscrire au WEI, lorsque les dates d'adhésion le permettent. Ceux qui se sont
|
N'importe quel⋅le utilisateur⋅rice peut s'auto-inscrire au WEI, lorsque les dates d'adhésion le permettent. Celleux qui se sont
|
||||||
déjà inscrits peuvent également inscrire un 1A. Seuls les GC WEI et les respo info peuvent inscrire un autre 2A+.
|
déjà inscrit⋅es peuvent également inscrire un⋅e 1A. Seul⋅es les GC WEI et les respos info peuvent inscrire un⋅e autre 2A+.
|
||||||
|
|
||||||
À tout moment, tant que le WEI n'est pas passé, l'inscription peut être modifiée, même après validation.
|
À tout moment, tant que le WEI n'est pas passé, l'inscription peut être modifiée, même après validation.
|
||||||
|
|
||||||
Inscription d'un 2A+
|
Inscription d'un⋅e 2A+
|
||||||
^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
Comme indiqué, les 2A+ sont assez autonomes dans leur inscription au WEI. Ils remplissent le questionnaire et sont
|
Comme indiqué, les 2A+ sont assez autonomes dans leur inscription au WEI. Iels remplissent le questionnaire et sont
|
||||||
ensuite pré-inscrits. Le questionnaire se compose de plusieurs champs (voir WEIRegistration) :
|
ensuite pré-inscrit⋅es. Le questionnaire se compose de plusieurs champs (voir WEIRegistration) :
|
||||||
|
|
||||||
* Est-ce que l'utilisateur a déclaré avoir ouvert un compte à la Société générale ? (Option disponible uniquemement
|
* Est-ce que l'utilisateur⋅rice a déclaré avoir ouvert un compte à la Société générale ? (Option disponible uniquemement
|
||||||
si cela n'a pas été fait une année avant)
|
si cela n'a pas été fait une année avant)
|
||||||
* Date de naissance
|
* Date de naissance
|
||||||
* Genre (Homme/Femme/Non-binaire)
|
* Genre (Homme/Femme/Non-binaire)
|
||||||
|
@ -159,17 +159,17 @@ ensuite pré-inscrits. Le questionnaire se compose de plusieurs champs (voir WEI
|
||||||
* Équipes préférées (choix multiple éventuellement vide, vide pour les chefs de bus/staff)
|
* Équipes préférées (choix multiple éventuellement vide, vide pour les chefs de bus/staff)
|
||||||
* Rôles souhaités
|
* Rôles souhaités
|
||||||
|
|
||||||
Les trois derniers champs n'ont aucun caractère définitif et sont simplement là en suggestion pour le GC WEI qui
|
Les trois derniers champs n'ont aucun caractère définitif et sont simplement là en suggestion pour læ GC WEI qui
|
||||||
validera l'inscription. C'est utile si on hésite entre plusieurs bus.
|
validera l'inscription. C'est utile si on hésite entre plusieurs bus.
|
||||||
|
|
||||||
L'inscription est ensuite créée, le GC WEI devra ensuite la valider (voir plus bas).
|
L'inscription est ensuite créée, le GC WEI devra ensuite la valider (voir plus bas).
|
||||||
|
|
||||||
Inscription d'un 1A
|
Inscription d'un⋅e 1A
|
||||||
^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
N'importe quelle personne déjà inscrite au WEI peut inscrire un 1A. Le formulaire 1A est assez peu différent du formulaire 2A+ :
|
N'importe quelle personne déjà inscrite au WEI peut inscrire un⋅e 1A. Le formulaire 1A est assez peu différent du formulaire 2A+ :
|
||||||
|
|
||||||
* Est-ce que l'utilisateur a déclaré avoir ouvert un compte à la Société générale ?
|
* Est-ce que l'utilisateur⋅rice a déclaré avoir ouvert un compte à la Société générale ?
|
||||||
* Date de naissance
|
* Date de naissance
|
||||||
* Genre (Homme/Femme/Non-binaire)
|
* Genre (Homme/Femme/Non-binaire)
|
||||||
* Problèmes de santé
|
* Problèmes de santé
|
||||||
|
@ -179,10 +179,10 @@ N'importe quelle personne déjà inscrite au WEI peut inscrire un 1A. Le formula
|
||||||
* S'inscrire à la ML BDA
|
* S'inscrire à la ML BDA
|
||||||
* S'inscrire à la ML BDS
|
* S'inscrire à la ML BDS
|
||||||
|
|
||||||
Le 1A ne peut donc pas choisir de son bus et de son équipe, et peut s'inscrire aux listes de diffusion.
|
Læ 1A ne peut donc pas choisir de son bus et de son équipe, et peut s'inscrire aux listes de diffusion.
|
||||||
Il y a néanmoins une différence majeure : une fois le formulaire rempli, un questionnaire se lance.
|
Il y a néanmoins une différence majeure : une fois le formulaire rempli, un questionnaire se lance.
|
||||||
Ce questionnaire peut varier au fil des années (voir section Questionnaire), et contient divers formulaires de collecte
|
Ce questionnaire peut varier au fil des années (voir section Questionnaire), et contient divers formulaires de collecte
|
||||||
de données qui serviront à déterminer quel est le meilleur bus pour ce nouvel utilisateur.
|
de données qui serviront à déterminer quel est le meilleur bus pour ce⋅tte nouvelleau utilisateur⋅rice.
|
||||||
|
|
||||||
Questionnaire 1A
|
Questionnaire 1A
|
||||||
^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^
|
||||||
|
@ -200,7 +200,7 @@ Je veux changer d'algorithme de répartition, que faire ?
|
||||||
|
|
||||||
Cette section est plus technique et s'adresse surtout aux respos info en cours de mandat.
|
Cette section est plus technique et s'adresse surtout aux respos info en cours de mandat.
|
||||||
|
|
||||||
Première règle : on ne supprime rien (sauf si vraiment c'est du mauvais boulot). En prenant exemple sur des fichiers déjà existant tels que ``apps/wei/forms/surveys/wei2020.py``, créer un nouveau fichier ``apps/wei/forms/surveys/wei20XY.py``. Ce fichier doit inclure les éléments suivants :
|
Première règle : on ne supprime rien (sauf si vraiment c'est du mauvais boulot). En prenant exemple sur des fichiers déjà existant tels que ``apps/wei/forms/surveys/wei2021.py``, créer un nouveau fichier ``apps/wei/forms/surveys/wei20XY.py``. Ce fichier doit inclure les éléments suivants :
|
||||||
|
|
||||||
WEISurvey
|
WEISurvey
|
||||||
"""""""""
|
"""""""""
|
||||||
|
@ -223,7 +223,7 @@ Une classe héritant de ``wei.forms.surveys.base.WEISurvey``, comportant les él
|
||||||
Naturellement, il est implicite qu'une fonction ayant pour premier argument ``cls`` doit être annotée par ``@classmethod``.
|
Naturellement, il est implicite qu'une fonction ayant pour premier argument ``cls`` doit être annotée par ``@classmethod``.
|
||||||
Nativement, la classe ``WEISurvey`` comprend les informations suivantes :
|
Nativement, la classe ``WEISurvey`` comprend les informations suivantes :
|
||||||
|
|
||||||
* ``registration``, le modèle ``WEIRegistration`` de l'utilisateur qui remplit le questionnaire
|
* ``registration``, le modèle ``WEIRegistration`` de l'utilisateur⋅rice qui remplit le questionnaire
|
||||||
* ``information``, instance de ``WEISurveyInformation``, contient les données du questionnaire en cours de remplissage.
|
* ``information``, instance de ``WEISurveyInformation``, contient les données du questionnaire en cours de remplissage.
|
||||||
* ``get_wei(cls)``, renvoie le WEI correspondant à l'année du sondage.
|
* ``get_wei(cls)``, renvoie le WEI correspondant à l'année du sondage.
|
||||||
* ``save(self)``, enregistre les informations du sondage dans l'objet ``registration`` associé, qui est ensuite
|
* ``save(self)``, enregistre les informations du sondage dans l'objet ``registration`` associé, qui est ensuite
|
||||||
|
@ -291,7 +291,7 @@ pour unique effet d'appeler la fonction ``run_algorithm`` décrite plus tôt. Un
|
||||||
n'a pas été évoqué d'adhésion. L'adhésion est ensuite manuelle, l'algorithme ne fournit qu'une suggestion.
|
n'a pas été évoqué d'adhésion. L'adhésion est ensuite manuelle, l'algorithme ne fournit qu'une suggestion.
|
||||||
|
|
||||||
Cette structure, complexe mais raisonnable, permet de gérer plus ou moins proprement la répartition des 1A,
|
Cette structure, complexe mais raisonnable, permet de gérer plus ou moins proprement la répartition des 1A,
|
||||||
en limitant très fortement le hard code. Ami nouveau développeur, merci de bien penser à la propreté du code :)
|
en limitant très fortement le hard code. Ami⋅e nouvelleau développeur⋅se, merci de bien penser à la propreté du code :)
|
||||||
En particulier, on évitera de mentionner dans le code le nom des bus, et profiter du champ ``information_json``
|
En particulier, on évitera de mentionner dans le code le nom des bus, et profiter du champ ``information_json``
|
||||||
présent dans le modèle ``Bus``.
|
présent dans le modèle ``Bus``.
|
||||||
|
|
||||||
|
@ -300,34 +300,34 @@ Valider les inscriptions
|
||||||
|
|
||||||
Cette partie est moins technique.
|
Cette partie est moins technique.
|
||||||
|
|
||||||
Une fois la pré-inscription faite, elle doit être validée par le BDE, afin de procéder au paiement. Le GC WEI a accès à
|
Une fois la pré-inscription faite, elle doit être validée par le BDE, afin de procéder au paiement. Læ GC WEI a accès à
|
||||||
la liste des inscriptions non validées, soit sur la page de détails du WEI, soit sur un tableau plus large avec filtre.
|
la liste des inscriptions non validées, soit sur la page de détails du WEI, soit sur un tableau plus large avec filtre.
|
||||||
Une inscription non validée peut soit être validée, soit supprimée (la suppression est irréversible).
|
Une inscription non validée peut soit être validée, soit supprimée (la suppression est irréversible).
|
||||||
|
|
||||||
Lorsque le GC WEI veut valider une inscription, il a accès au récapitulatif de l'inscription ainsi qu'aux informations
|
Lorsque læ GC WEI veut valider une inscription, iel a accès au récapitulatif de l'inscription ainsi qu'aux informations
|
||||||
personnelles de l'utilisateur. Il lui est proposé de les modifier si besoin (du moins les informations liées au WEI,
|
personnelles de l'utilisateur⋅rice. Il lui est proposé de les modifier si besoin (du moins les informations liées au WEI,
|
||||||
pas les informations personnelles). Il a enfin accès aux résultats du sondage et la sortie de l'algorithme s'il s'agit
|
pas les informations personnelles). Iel a enfin accès aux résultats du sondage et la sortie de l'algorithme s'il s'agit
|
||||||
d'un 1A, aux préférences d'un 2A+. Avant de valider, le GC WEI doit sélectionner un bus, éventuellement une équipe
|
d'un⋅e 1A, aux préférences d'un⋅e 2A+. Avant de valider, læ GC WEI doit sélectionner un bus, éventuellement une équipe
|
||||||
et un rôle. Si c'est un 1A et que l'algorithme a tourné, ou si c'est un 2A+ qui n'a fait qu'un seul choix de bus,
|
et un rôle. Si c'est un⋅e 1A et que l'algorithme a tourné, ou si c'est un⋅e 2A+ qui n'a fait qu'un seul choix de bus,
|
||||||
d'équipe, de rôles, les champs sont automatiquement pré-remplis.
|
d'équipe, de rôles, les champs sont automatiquement pré-remplis.
|
||||||
|
|
||||||
Quelques restrictions cependant :
|
Quelques restrictions cependant :
|
||||||
|
|
||||||
* Si c'est un 2A+, le chèque de caution doit être déclaré déposé
|
* Si c'est un⋅e 2A+, le chèque de caution doit être déclaré déposé
|
||||||
* Si l'inscription se fait via la Société générale, un message expliquant la situation apparaît : la transaction de
|
* Si l'inscription se fait via la Société générale, un message expliquant la situation apparaît : la transaction de
|
||||||
paiement sera créée mais invalidée, les trésoriers devront confirmer plus tard sur leur interface que le compte
|
paiement sera créée mais invalidée, les trésorièr⋅es devront confirmer plus tard sur leur interface que le compte
|
||||||
à la Société générale a bien été créé avant de valider la transaction (voir `Trésorerie <treasury>`_ section
|
à la Société générale a bien été créé avant de valider la transaction (voir `Trésorerie <treasury>`_ section
|
||||||
Crédit de la Société générale).
|
Crédit de la Société générale).
|
||||||
* Dans le cas contraire, l'utilisateur doit avoir le solde nécessaire sur sa note avant de pouvoir adhérer.
|
* Dans le cas contraire, l'utilisateur⋅rice doit avoir le solde nécessaire sur sa note avant de pouvoir adhérer.
|
||||||
* L'utilisateur doit enfin être membre du club Kfet. Un lien est présent pour le faire adhérer ou réadhérer selon le cas.
|
* L'utilisateur⋅rice doit enfin être membre du club Kfet. Un lien est présent pour le faire adhérer ou réadhérer selon le cas.
|
||||||
|
|
||||||
Si tout est bon, le GC WEI peut valider. L'utilisateur a bien payé son WEI, et son interface est un peu plus grande.
|
Si tout est bon, læ GC WEI peut valider. L'utilisateur⋅rice a bien payé son WEI, et son interface est un peu plus grande.
|
||||||
Il peut toujours changer ses paramètres au besoin. Un 1A ne voit rien de plus avant la fin du WEI.
|
Iel peut toujours changer ses paramètres au besoin. Un⋅e 1A ne voit rien de plus avant la fin du WEI.
|
||||||
|
|
||||||
Un adhérent WEI non 1A a accès à la liste des bus, des équipes et de leur descriptions. Les chefs de bus peuvent gérer
|
Un⋅e adhérent⋅e WEI non 1A a accès à la liste des bus, des équipes et de leur descriptions. Les chef⋅fes de bus peuvent gérer
|
||||||
les bus et leurs équipes. Les chefs d'équipe peuvent gérer leurs équipes. Cela inclut avoir accès à la liste des membres
|
les bus et leurs équipes. Les chef⋅fes d'équipe peuvent gérer leurs équipes. Cela inclut avoir accès à la liste des membres
|
||||||
de ce bus / de cette équipe.
|
de ce bus / de cette équipe.
|
||||||
|
|
||||||
Un export au format PDF de la liste des membres *visibles* est disponible pour chacun.
|
Un export au format PDF de la liste des membres *visibles* est disponible pour chacun⋅e.
|
||||||
|
|
||||||
Bon WEI à tous !
|
Bon WEI à toustes !
|
||||||
|
|
|
@ -3,7 +3,7 @@ Service d'Authentification Centralisé (CAS)
|
||||||
|
|
||||||
Un `CAS <https://fr.wikipedia.org/wiki/Central_Authentication_Service>`_ est
|
Un `CAS <https://fr.wikipedia.org/wiki/Central_Authentication_Service>`_ est
|
||||||
déployé sur la Note Kfet. Il est accessible à l'adresse `<https://note.crans.org/cas/>`_.
|
déployé sur la Note Kfet. Il est accessible à l'adresse `<https://note.crans.org/cas/>`_.
|
||||||
Il a pour but uniquement d'authentifier les utilisateurs via la note et ne communique
|
Il a pour but uniquement d'authentifier les utilisateur⋅rices via la note et ne communique
|
||||||
que peu d'informations.
|
que peu d'informations.
|
||||||
|
|
||||||
Configuration
|
Configuration
|
||||||
|
|
|
@ -12,10 +12,10 @@ Applications externes
|
||||||
L'utilisation de la note par des services externes est actuellement en beta. Il est
|
L'utilisation de la note par des services externes est actuellement en beta. Il est
|
||||||
fort à parier que cette utilisation sera revue et améliorée à l'avenir.
|
fort à parier que cette utilisation sera revue et améliorée à l'avenir.
|
||||||
|
|
||||||
Puisque la Note Kfet recense tous les comptes des adhérents BDE, les clubs ont alors
|
Puisque la Note Kfet recense tous les comptes des adhérent⋅es BDE, les clubs ont alors
|
||||||
la possibilité de développer leurs propres applications et de les interfacer avec la
|
la possibilité de développer leurs propres applications et de les interfacer avec la
|
||||||
note. De cette façon, chaque application peut authentifier ses utilisateurs via la note,
|
note. De cette façon, chaque application peut authentifier ses utilisateur⋅rices via la note,
|
||||||
et récupérer leurs adhésion, leur nom de note afin d'éventuellement faire des transferts
|
et récupérer leurs adhésions, leur nom de note afin d'éventuellement faire des transferts
|
||||||
via l'API.
|
via l'API.
|
||||||
|
|
||||||
Deux protocoles d'authentification sont implémentées :
|
Deux protocoles d'authentification sont implémentées :
|
||||||
|
@ -25,4 +25,4 @@ Deux protocoles d'authentification sont implémentées :
|
||||||
|
|
||||||
À ce jour, il n'y a pas encore d'exemple d'utilisation d'application qui utilise ce
|
À ce jour, il n'y a pas encore d'exemple d'utilisation d'application qui utilise ce
|
||||||
mécanisme, mais on peut imaginer par exemple que la Mediatek ou l'AMAP implémentent
|
mécanisme, mais on peut imaginer par exemple que la Mediatek ou l'AMAP implémentent
|
||||||
ces protocoles pour récupérer leurs adhérents.
|
ces protocoles pour récupérer leurs adhérent⋅es.
|
||||||
|
|
|
@ -2,12 +2,12 @@ OAuth2
|
||||||
======
|
======
|
||||||
|
|
||||||
L'authentification `OAuth2 <https://fr.wikipedia.org/wiki/OAuth>`_ est supportée par la
|
L'authentification `OAuth2 <https://fr.wikipedia.org/wiki/OAuth>`_ est supportée par la
|
||||||
Note Kfet. Elle offre l'avantage non seulement d'identifier les utilisateurs, mais aussi
|
Note Kfet. Elle offre l'avantage non seulement d'identifier les utilisateur⋅rices, mais
|
||||||
de transmettre des informations à un service tiers tels que des informations personnelles,
|
aussi de transmettre des informations à un service tiers tels que des informations
|
||||||
le solde de la note ou encore les adhésions de l'utilisateur, en l'avertissant sur
|
personnelles, le solde de la note ou encore les adhésions de l'utilisateur⋅rice, en
|
||||||
quelles données sont effectivement collectées. Ainsi, il est possible de développer des
|
l'avertissant sur quelles données sont effectivement collectées. Ainsi, il est possible
|
||||||
appplications tierces qui peuvent se baser sur les données de la Note Kfet ou encore
|
de développer des appplications tierces qui peuvent se baser sur les données de la Note
|
||||||
faire des transactions.
|
Kfet ou encore faire des transactions.
|
||||||
|
|
||||||
|
|
||||||
Configuration du serveur
|
Configuration du serveur
|
||||||
|
@ -79,7 +79,7 @@ Il vous suffit de donner à votre application :
|
||||||
* Les scopes, qui peuvent être récupérées sur cette page : `<https://note.crans.org/permission/scopes/>`_
|
* Les scopes, qui peuvent être récupérées sur cette page : `<https://note.crans.org/permission/scopes/>`_
|
||||||
* L'URL d'autorisation : `<https://note.crans.org/o/authorize/>`_
|
* L'URL d'autorisation : `<https://note.crans.org/o/authorize/>`_
|
||||||
* L'URL d'obtention de jeton : `<https://note.crans.org/o/token/>`_
|
* L'URL d'obtention de jeton : `<https://note.crans.org/o/token/>`_
|
||||||
* Si besoin, l'URL de récupération des informations de l'utilisateur : `<https://note.crans.org/api/me/>`_
|
* Si besoin, l'URL de récupération des informations de l'utilisateur⋅rice : `<https://note.crans.org/api/me/>`_
|
||||||
|
|
||||||
N'hésitez pas à consulter la page `<https://note.crans.org/api/me/>`_ pour s'imprégner
|
N'hésitez pas à consulter la page `<https://note.crans.org/api/me/>`_ pour s'imprégner
|
||||||
du format renvoyé.
|
du format renvoyé.
|
||||||
|
@ -88,14 +88,14 @@ du format renvoyé.
|
||||||
|
|
||||||
Un petit mot sur les scopes : tel qu'implémenté, une scope est une permission unitaire
|
Un petit mot sur les scopes : tel qu'implémenté, une scope est une permission unitaire
|
||||||
(telle que décrite dans le modèle ``Permission``) associée à un club. Ainsi, un jeton
|
(telle que décrite dans le modèle ``Permission``) associée à un club. Ainsi, un jeton
|
||||||
a accès à une scope si et seulement si le/la propriétaire du jeton dispose d'une adhésion
|
a accès à une scope si et seulement si læ propriétaire du jeton dispose d'une adhésion
|
||||||
courante dans le club lié à la scope qui lui octroie cette permission.
|
courante dans le club lié à la scope qui lui octroie cette permission.
|
||||||
|
|
||||||
Par exemple, un jeton pourra avoir accès à la permission de créer des transactions en lien
|
Par exemple, un jeton pourra avoir accès à la permission de créer des transactions en lien
|
||||||
avec un club si et seulement si le propriétaire du jeton est trésorier du club.
|
avec un club si et seulement si læ propriétaire du jeton est trésorièr⋅e du club.
|
||||||
|
|
||||||
La vérification des droits du propriétaire est faite systématiquement, afin de ne pas
|
La vérification des droits de læ propriétaire est faite systématiquement, afin de ne pas
|
||||||
faire confiance au jeton en cas de droits révoqués à son propriétaire.
|
faire confiance au jeton en cas de droits révoqués à saon propriétaire.
|
||||||
|
|
||||||
Vous pouvez donc contrôler le plus finement possible les permissions octroyées à vos
|
Vous pouvez donc contrôler le plus finement possible les permissions octroyées à vos
|
||||||
jetons.
|
jetons.
|
||||||
|
@ -118,8 +118,8 @@ du format renvoyé.
|
||||||
|
|
||||||
Par exemple, vous pourriez demander la permission d'accéder
|
Par exemple, vous pourriez demander la permission d'accéder
|
||||||
aux membres d'un club ou de faire des transactions, et agir
|
aux membres d'un club ou de faire des transactions, et agir
|
||||||
uniquement dans le cas où l'utilisateur connecté possède la
|
uniquement dans le cas où l'utilisateur⋅rice connecté⋅e
|
||||||
permission problématique.
|
possède la permission problématique.
|
||||||
|
|
||||||
Avec Django-allauth
|
Avec Django-allauth
|
||||||
###################
|
###################
|
||||||
|
@ -152,7 +152,7 @@ Le paramètre ``DOMAIN`` permet de changer d'instance de Note Kfet. Par défaut,
|
||||||
se connectera à ``note.crans.org`` si vous ne renseignez rien.
|
se connectera à ``note.crans.org`` si vous ne renseignez rien.
|
||||||
|
|
||||||
Le paramètre ``SCOPE`` permet de définir les scopes à demander.
|
Le paramètre ``SCOPE`` permet de définir les scopes à demander.
|
||||||
Dans l'exemple ci-dessous, les permissions d'accéder à l'utilisateur
|
Dans l'exemple ci-dessous, les permissions d'accéder à l'utilisateur⋅rice
|
||||||
et au profil sont demandées.
|
et au profil sont demandées.
|
||||||
|
|
||||||
En créant l'application sur la note, vous pouvez renseigner
|
En créant l'application sur la note, vous pouvez renseigner
|
||||||
|
@ -200,7 +200,7 @@ cas où elle n'est pas explicitement indiquée lors de l'autorisation.
|
||||||
|
|
||||||
Lorsqu'un client veut s'authentifier via la Note Kfet, il va devoir accéder à une page
|
Lorsqu'un client veut s'authentifier via la Note Kfet, il va devoir accéder à une page
|
||||||
d'authentification. La page d'autorisation est `<https://note.crans.org/o/authorize/>`_,
|
d'authentification. La page d'autorisation est `<https://note.crans.org/o/authorize/>`_,
|
||||||
c'est sur cette page qu'il faut rediriger les utilisateurs. Il faut mettre en paramètre GET :
|
c'est sur cette page qu'il faut rediriger les utilisateur⋅rices. Il faut mettre en paramètre GET :
|
||||||
|
|
||||||
* ``client_id`` : l'identifiant client de l'application (public) ;
|
* ``client_id`` : l'identifiant client de l'application (public) ;
|
||||||
* ``response_type`` : mettre ``code`` ;
|
* ``response_type`` : mettre ``code`` ;
|
||||||
|
@ -211,10 +211,10 @@ c'est sur cette page qu'il faut rediriger les utilisateurs. Il faut mettre en pa
|
||||||
* ``state`` : optionnel, peut être utilisé pour permettre au client de détecter des requêtes
|
* ``state`` : optionnel, peut être utilisé pour permettre au client de détecter des requêtes
|
||||||
provenant d'autres sites.
|
provenant d'autres sites.
|
||||||
|
|
||||||
Sur cette page, les permissions demandées seront listées, et l'utilisateur aura le choix
|
Sur cette page, les permissions demandées seront listées, et l'utilisateur⋅rice aura le
|
||||||
d'accepter ou non. Dans les deux cas, l'utilisateur sera redirigée vers ``redirect_uri``,
|
choix d'accepter ou non. Dans les deux cas, l'utilisateur⋅rice sera redirigée vers
|
||||||
avec pour paramètre GET soit le message d'erreur, soit un paramètre ``code`` correspondant
|
``redirect_uri``, avec pour paramètre GET soit le message d'erreur, soit un paramètre
|
||||||
au code d'autorisation.
|
``code`` correspondant au code d'autorisation.
|
||||||
|
|
||||||
Une fois ce code d'autorisation récupéré, il faut désormais récupérer le jeton d'accès.
|
Une fois ce code d'autorisation récupéré, il faut désormais récupérer le jeton d'accès.
|
||||||
Il faut pour cela aller sur l'URL `<https://note.crans.org/o/token/>`_, effectuer une
|
Il faut pour cela aller sur l'URL `<https://note.crans.org/o/token/>`_, effectuer une
|
||||||
|
|
167
docs/faq.rst
167
docs/faq.rst
|
@ -5,27 +5,26 @@ Des transactions anormales sont apparues sur mon compte.
|
||||||
--------------------------------------------------------
|
--------------------------------------------------------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
Tu dois immédiatement contacter les trésoriers du BDE (voir ci-dessous) pour
|
Tu dois immédiatement contacter les trésorièr⋅es du BDE (voir ci-dessous) pour
|
||||||
signaler l'incident. Précise bien ton nom de note, l'heure de la transaction
|
signaler l'incident. Précise bien ton nom de note, l'heure de la transaction ainsi que
|
||||||
ainsi que l'alias utilisé pour faire la transaction (en plaçant ta souris sur
|
l'alias utilisé pour faire la transaction (en plaçant ta souris sur ton pseudo sur la
|
||||||
ton pseudo sur la ligne de transaction, l'alias utilisé apparaît). La raison
|
ligne de transaction, l'alias utilisé apparaît). La raison la plus courante est que tu
|
||||||
la plus courante est que tu as un alias qui est trop proche d'un autre d'une
|
as un alias qui est trop proche d'une autre personne. Même si la Note Kfet 2020 essaie
|
||||||
autre personne. Même si la Note Kfet 2020 essaie d'éviter ça, tu es invité⋅e
|
d'éviter ça, tu es invité⋅e à supprimer l'alias problématique, ou tout du moins
|
||||||
à supprimer l'alias problématique, ou tout du moins t'assurer que la confusion
|
t'assurer que la confusion ne puisse plus arriver.
|
||||||
ne puisse plus arriver.
|
|
||||||
|
|
||||||
|
|
||||||
Je souhaite consommer mais le solde de ma note est insuffisant
|
Je souhaite consommer mais le solde de ma note est insuffisant
|
||||||
--------------------------------------------------------------
|
--------------------------------------------------------------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
Le BDE ne fait pas crédit à ses adhérents. Il est de ton devoir de t'assurer
|
Le BDE ne fait pas crédit à ses adhérent⋅es. Il est de ton devoir de t'assurer d'avoir
|
||||||
d'avoir en permanence un solde positif sur ta note. Les permanenciers à la
|
en permanence un solde positif sur ta note. Les permanencièr⋅es à la Kfet ont la
|
||||||
Kfet ont la possibilité de refuser une consommation qui fait passer en négatif,
|
possibilité de refuser une consommation qui fait passer en négatif, et ont obligation
|
||||||
et ont obligation de refuser si la consommation est alcoolisée, en accord avec
|
de refuser si la consommation est alcoolisée, en accord avec la règlementation en
|
||||||
la règlementation en vigueur.
|
vigueur.
|
||||||
|
|
||||||
Les trésoriers connaissent la liste des personnes en situation irrégulière et
|
Les trésorièr⋅es connaissent la liste des personnes en situation irrégulière et
|
||||||
n'hésiteront pas à faire des rappels pour recharger la note.
|
n'hésiteront pas à faire des rappels pour recharger la note.
|
||||||
|
|
||||||
|
|
||||||
|
@ -33,10 +32,10 @@ Comment recharger ma note ?
|
||||||
---------------------------
|
---------------------------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
Le solde de la note peut être rechargé soit par espèces, par chèque à l'ordre
|
Le solde de la note peut être rechargé soit par espèces, par chèque à l'ordre de
|
||||||
de l'amicale des élèves de l'ENS Cachan, par carte bancaire via un terminal
|
l'amicale des élèves de l'ENS Paris-Saclay, par carte bancaire via un terminal de
|
||||||
de paiement électronique ou encore par virement bancaire, dont les coordonnées
|
paiement électronique ou encore par virement bancaire, dont les coordonnées sont à
|
||||||
sont à demander auprès des trésoriers BDE.
|
demander auprès des trésorièr⋅es BDE.
|
||||||
|
|
||||||
Les trois premières options sont à faire directement dans la Kfet.
|
Les trois premières options sont à faire directement dans la Kfet.
|
||||||
|
|
||||||
|
@ -45,9 +44,9 @@ Je pars en stage / en vacances. Puis-je bloquer ma note ?
|
||||||
---------------------------------------------------------
|
---------------------------------------------------------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
Bien sûr : il te suffit de te rendre sur ton compte et de cliquer sur le bouton
|
Bien sûr : il te suffit de te rendre sur ton compte et de cliquer sur le bouton dédié.
|
||||||
dédié. Ta note ne sera plus affichée par les autres personnes et les transferts
|
Ta note ne sera plus affichée par les autres personnes et les transferts seront
|
||||||
seront impossibles, sauf pour les trésoriers BDE et respo info.
|
impossibles, sauf pour les trésorièr⋅es BDE et respo info.
|
||||||
|
|
||||||
Il est toutefois de ton devoir de rembourser tout ce que tu dois.
|
Il est toutefois de ton devoir de rembourser tout ce que tu dois.
|
||||||
|
|
||||||
|
@ -56,88 +55,87 @@ Quelle est la limite maximale au nombre d'alias d'une note ?
|
||||||
------------------------------------------------------------
|
------------------------------------------------------------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
Certains parlent d'une dizaine d'alias par note.
|
Certain⋅es parlent d'une dizaine d'alias par note.
|
||||||
|
|
||||||
Sois conscient⋅e qu'ajouter des alias ne peut qu'augmenter la probabilité de
|
Sois conscient⋅e qu'ajouter des alias ne peut qu'augmenter la probabilité de
|
||||||
collisions avec une autre note, et peut aussi retarder la livraison de ta
|
collisions avec une autre note, et peut aussi retarder la livraison de ta commande
|
||||||
commande lors d'un perm bouffe.
|
lors d'une perm bouffe.
|
||||||
|
|
||||||
|
|
||||||
Je suis trésorier d'un club, qu'ai-je le droit de faire ?
|
Je suis trésorièr⋅e d'un club, qu'ai-je le droit de faire ?
|
||||||
---------------------------------------------------------
|
-----------------------------------------------------------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
Être trésorier d'un club donne la responsabilité de gérer la trésorerie du
|
Être trésorièr⋅e d'un club donne la responsabilité de gérer la trésorerie du club, et
|
||||||
club, et donc de gérer sa note. Vous obtenez donc le droit d'effectuer
|
donc de gérer sa note. Vous obtenez donc le droit d'effectuer n'importe quelle
|
||||||
n'importe quelle transaction via la note en provenance ou à destination de
|
transaction via la note en provenance ou à destination de la note de votre club. Vous
|
||||||
la note de votre club. Vous pouvez également gérer les adhésions de votre club,
|
pouvez également gérer les adhésions de votre club, en permettant à n'importe quel⋅le
|
||||||
en permettant à n'importe quel adhérent BDE de rejoindre votre club, en prélevant
|
adhérent⋅e BDE de rejoindre votre club, en prélevant d'éventuels frais d'adhésion. Les
|
||||||
d'éventuels frais d'adhésion. Les paramètres du club peuvent être également modifiés.
|
paramètres du club peuvent être également modifiés.
|
||||||
|
|
||||||
.. danger::
|
.. danger::
|
||||||
Avoir des droits sur la Note Kfet ne signifie pas que vous devez les utiliser.
|
Avoir des droits sur la Note Kfet ne signifie pas que vous devez les utiliser. Chaque
|
||||||
Chaque opération nécessitant des droits doit être fait pour une bonne raison,
|
opération nécessitant des droits doit être fait pour une bonne raison, et doit avoir
|
||||||
et doit avoir un lien avec votre club. Vous n'avez par exemple pas le droit
|
un lien avec votre club. Vous n'avez par exemple pas le droit d'aller récupérer des
|
||||||
d'aller récupérer des informations personnelles d'adhérents pour une raison
|
informations personnelles d'adhérent⋅es pour une raison personnelle. En revanche,
|
||||||
personnelle. En revanche, faire le lien entre nom/prénom et nom de note est
|
faire le lien entre nom/prénom et nom de note est bien sûr permis pour faciliter des
|
||||||
bien sûr permis pour faciliter des transferts. Tout abus de droits constaté
|
transferts. Tout abus de droits constaté pourra mener à des sanctions prises par le
|
||||||
pourra mener à des sanctions prises par le bureau du BDE.
|
bureau du BDE.
|
||||||
|
|
||||||
|
|
||||||
Je suis trésorier d'un club, je n'arrive pas à voir le solde du club / faire des transactions
|
Je suis trésorièr⋅e d'un club, je n'arrive pas à voir le solde du club / faire des transactions
|
||||||
---------------------------------------------------------------------------------------------------
|
-----------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
As-tu bien vérifié que tu t'es connecté⋅e initialement avec tous tes droits ?
|
As-tu bien vérifié que tu t'es connecté⋅e initialement avec tous tes droits ? Sinon,
|
||||||
Sinon, si tes droits sont tout récents, tu dois te déconnecter et te reconnecter
|
si tes droits sont tout récents, tu dois te déconnecter et te reconnecter pour que tes
|
||||||
pour que tes droits soient bien pris en compte.
|
droits soient bien pris en compte.
|
||||||
|
|
||||||
La Note permet de se connecter avec différents filtres de permission afin de
|
La Note permet de se connecter avec différents filtres de permission afin de pouvoir
|
||||||
pouvoir prêter son ordinateur avec une session ouverte pour faire quelques
|
prêter son ordinateur avec une session ouverte pour faire quelques opérations en
|
||||||
opérations en empêchant l'accès à des opérations trop sensibles.
|
empêchant l'accès à des opérations trop sensibles.
|
||||||
|
|
||||||
|
|
||||||
Je suis trésorier d'un club. Puis-je créer un bouton ?
|
Je suis trésorièr⋅e d'un club. Puis-je créer un bouton ?
|
||||||
------------------------------------------------------
|
--------------------------------------------------------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
Oui bien sûr ! Tant qu'il redirige bien vers la note de ton club.
|
Oui bien sûr ! Tant qu'il redirige bien vers la note de ton club.
|
||||||
|
|
||||||
Pour cela, rends-toi à la page `</note/buttons/>`_ pour afficher la liste des
|
Pour cela, rends-toi à la page `</note/buttons/>`_ pour afficher la liste des boutons,
|
||||||
boutons, puis tu auras accès à l'interface pour créer un bouton. Une fois le
|
puis tu auras accès à l'interface pour créer un bouton. Une fois le bouton créé, il
|
||||||
bouton créé, il apparaîtra dans l'onglet ``Consommations``.
|
apparaîtra dans l'onglet ``Consommations``.
|
||||||
|
|
||||||
Il faut noter que tant qu'il n'y a pas de boutons visibles pour ton club, tu
|
Il faut noter que tant qu'il n'y a pas de boutons visibles pour ton club, tu n'auras
|
||||||
n'auras pas accès à l'interface de consommations, et tu devras nécessairement
|
pas accès à l'interface de consommations, et tu devras nécessairement cliquer sur le
|
||||||
cliquer sur le lien ci-dessus pour accéder à l'interface d'édition des boutons.
|
lien ci-dessus pour accéder à l'interface d'édition des boutons. Une fois qu'un bouton
|
||||||
Une fois qu'un bouton pour ton club est visible, l'interface consommations
|
pour ton club est visible, l'interface consommations devient accessible.
|
||||||
devient accessible.
|
|
||||||
|
|
||||||
|
|
||||||
Après passation, je suis trésorier d'un club. Comment récupérer mes droits note ?
|
Après passation, je suis trésorièr⋅e d'un club. Comment récupérer mes droits note ?
|
||||||
---------------------------------------------------------------------------------
|
-----------------------------------------------------------------------------------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
Tu dois pour cela contacter les trésoriers BDE (voir ci-dessous). Ils vous
|
Tu dois pour cela contacter les trésorièr⋅es BDE (voir ci-dessous). Iels vous
|
||||||
expliqueront en détails vos droits et vos interdits et vous donneront les
|
expliqueront en détails vos droits et vos interdits et vous donneront les droits
|
||||||
droits requis.
|
requis.
|
||||||
|
|
||||||
|
|
||||||
Je souhaite contacter un trésorier
|
Je souhaite contacter un⋅e trésorièr⋅e
|
||||||
----------------------------------
|
--------------------------------------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
Pour contacter un trésorier, il te suffit d'envoyer un mail à l'adresse
|
Pour contacter un⋅e trésorièr⋅e, il te suffit d'envoyer un mail à l'adresse
|
||||||
`tresorerie.bde@lists.crans.org <tresorerie.bde@lists.crans.org>`_. Pense bien
|
`tresorerie.bde@lists.crans.org <tresorerie.bde@lists.crans.org>`_. Pense bien à
|
||||||
à donner ton nom de note, voire à envoyer un scan de ta carte d'identité si ta
|
donner ton nom de note, voire à envoyer un scan de ta carte d'identité si ta demande
|
||||||
demande concerne un virement entre le compte du BDE et ton propre compte.
|
concerne un virement entre le compte du BDE et ton propre compte.
|
||||||
|
|
||||||
|
|
||||||
J'ai trouvé un bug, comment le signaler ?
|
J'ai trouvé un bug, comment le signaler ?
|
||||||
-----------------------------------------
|
-----------------------------------------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
La Note Kfet est développée bénévolement par des membres du BDE. Malgré tous nos
|
La Note Kfet est développée bénévolement par des membres du BDE. Nous mettons tous nos
|
||||||
efforts pour fournir une plateforme sans erreur et la plus ergonomique possible.
|
efforts pour fournir une plateforme sans erreur et la plus ergonomique possible.
|
||||||
Toutefois, il n'est évidemment pas exclu que des bugs soient présents :)
|
Toutefois, il n'est évidemment pas exclu que des bugs soient présents :)
|
||||||
|
|
||||||
|
@ -156,41 +154,42 @@ Je souhaite contribuer
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
La Note Kfet est essentiellement développée par des responsables informatiques du
|
La Note Kfet est essentiellement développée par des responsables informatiques du BDE
|
||||||
BDE de l'ENS Paris-Saclay. Toutefois, si vous souhaitez contribuer, vous pouvez
|
de l'ENS Paris-Saclay. Toutefois, si vous souhaitez contribuer, vous pouvez bien sûr
|
||||||
bien sûr le faire en accord avec la licence GPLv3 avec laquelle la Note Kfet est
|
le faire en accord avec la licence GPLv3 avec laquelle la Note Kfet est distribuée.
|
||||||
distribuée. Pour cela, si vous êtes adhérent Crans, vous pouvez proposer une
|
Pour cela, si vous êtes adhérent⋅e Crans, vous pouvez proposer une demande de fusion
|
||||||
demande de fusion de votre code. Si ce n'est pas le cas, vous pouvez envoyer un
|
de votre code. Si ce n'est pas le cas, vous pouvez envoyer un mail à
|
||||||
mail à `notekfet2020@lists.crans.org <notekfet2020@lists.crans.org>`_.
|
`notekfet2020@lists.crans.org <notekfet2020@lists.crans.org>`_. Dans les deux cas,
|
||||||
Dans les deux cas, merci de rejoindre le canal ``#note`` sur IRC :)
|
merci de rejoindre le canal ``#note`` sur IRC :)
|
||||||
|
|
||||||
|
|
||||||
Contributeurs
|
Contributeur⋅rices
|
||||||
-------------
|
------------------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
La version 2020 de la Note Kfet a été développée sous le mandat de la
|
La version 2020 de la Note Kfet a été développée sous le mandat de la
|
||||||
Saper[list]popette. Son développement a commencé à l'été 2019. Après un mois de beta
|
Saper[list]popette. Son développement a commencé à l'été 2019. Après un mois de beta à
|
||||||
à l'été 2020, son déploiement en production s'est fait le samedi 5 septembre 2020.
|
l'été 2020, son déploiement en production s'est fait le samedi 5 septembre 2020.
|
||||||
|
|
||||||
Elle succède à presque 6 années de la
|
Elle succède à presque 6 années de la
|
||||||
`Note Kfet 2015 <https://wiki.crans.org/NoteKfet/NoteKfet2015>`_, alors en production
|
`Note Kfet 2015 <https://wiki.crans.org/NoteKfet/NoteKfet2015>`_, alors en production
|
||||||
depuis le 6 octobre 2014.
|
depuis le 6 octobre 2014.
|
||||||
|
|
||||||
Liste des contributeurs majeurs, par ordre alphabétique :
|
Liste des contributeur⋅rices majeur⋅es, par ordre alphabétique :
|
||||||
|
|
||||||
* Pierre-André « PAC » COMBY
|
* Pierre-André « PAC » COMBY
|
||||||
* Yohann « ÿnérant » D'ANELLO
|
* Emmy « ÿnérant » D'ANELLO
|
||||||
* Benjamin « esum » GRAILLOT
|
* Benjamin « esum » GRAILLOT
|
||||||
* Alexandre « erdnaxe » IOOSS
|
* Alexandre « erdnaxe » IOOSS
|
||||||
|
* Nicolas « nicomarg » MARGULIES
|
||||||
|
|
||||||
|
|
||||||
Hébergement
|
Hébergement
|
||||||
-----------
|
-----------
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
En accord entre de l'ENS Paris-Saclay et le Crans, l'instance de production présente
|
En accord entre le BDE de l'ENS Paris-Saclay et le Crans, l'instance de production
|
||||||
sur `<https://note.crans.org/>`_ est hébergée sur l'un des serveurs du Crans.
|
présente sur `<https://note.crans.org/>`_ est hébergée sur l'un des serveurs du Crans.
|
||||||
Les données sont hébergées à l'adresse :
|
Les données sont hébergées à l'adresse :
|
||||||
|
|
||||||
.. code::
|
.. code::
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
La note, c'est quoi ?
|
La note, c'est quoi ?
|
||||||
=====================
|
=====================
|
||||||
|
|
||||||
La Note Kfet est un porte-monnaie virtuel proposé gratuitement à tous les adhérents BDE.
|
La Note Kfet est un porte-monnaie virtuel proposé gratuitement à toustes les
|
||||||
C'est le moyen de paiement privilégié au sein du campus, que ce soit pour payer des
|
adhérent⋅es BDE. C'est le moyen de paiement privilégié au sein du campus, que ce soit
|
||||||
activités du BDE, ou bien pour faire des remboursements entre amis. La note contient
|
pour payer des activités du BDE, ou bien pour faire des remboursements entre ami⋅es.
|
||||||
également la base d'adhérents du BDE et contient de nombreux outils facilitant la vie
|
La note contient également la base d'adhérent⋅es du BDE et contient de nombreux outils
|
||||||
des différents bureaux de clubs, en particulier les trésoriers et surtout les trésoriers
|
facilitant la vie des différents bureaux de clubs, en particulier les trésorièr⋅es et
|
||||||
BDE.
|
surtout les trésorièr⋅es BDE.
|
||||||
|
|
||||||
La Note Kfet est accessible à l'adresse `<https://note.crans.org>`_. La version actuelle
|
La Note Kfet est accessible à l'adresse `<https://note.crans.org>`_. La version actuelle
|
||||||
a été développée par le BDE 2020-2021, et est maintenue par les respos infos du BDE de
|
a été développée par le BDE 2020-2021, et est maintenue par les respos infos du BDE de
|
||||||
|
@ -23,7 +23,7 @@ Chaque adhérent⋅e BDE dispose d'un compte appelé « note », créé lors de
|
||||||
Une note est associée à un solde en euros, et à un pseudo appelé « nom de note ».
|
Une note est associée à un solde en euros, et à un pseudo appelé « nom de note ».
|
||||||
Le solde associé à la note correspond au solde de l'adhérent⋅e, avec lequel il est
|
Le solde associé à la note correspond au solde de l'adhérent⋅e, avec lequel il est
|
||||||
possible de payer tout ce qui est en lien avec le BDE. Le nom de note suffit à
|
possible de payer tout ce qui est en lien avec le BDE. Le nom de note suffit à
|
||||||
identifier une personne, et il suffit par exemple de donner ce nom à un permanencier
|
identifier une personne, et il suffit par exemple de donner ce nom à un⋅e permanencièr⋅e
|
||||||
à la Kfet pour acheter un produit.
|
à la Kfet pour acheter un produit.
|
||||||
|
|
||||||
Faire une transaction
|
Faire une transaction
|
||||||
|
@ -34,10 +34,10 @@ d'un⋅e autre adhérent⋅e, pourvu que le montant de la transaction n'excède
|
||||||
propre solde. Pour cela, il suffit d'aller sur la page de transferts, qui est la
|
propre solde. Pour cela, il suffit d'aller sur la page de transferts, qui est la
|
||||||
page par défaut après connexion : `<https://note.crans.org/note/transfer/>`_
|
page par défaut après connexion : `<https://note.crans.org/note/transfer/>`_
|
||||||
Le formulaire pour effectuer un transfert apparaît alors. En cliquant sur le bouton
|
Le formulaire pour effectuer un transfert apparaît alors. En cliquant sur le bouton
|
||||||
« Je suis l'émetteur », le champ « Émetteurs » est directement complété avec votre
|
« Je suis l'émetteur⋅rice », le champ « Émetteur⋅rices » est directement complété
|
||||||
propre note. Il vous suffit alors de remplir le champ « Destinataires » avec le ou
|
avec votre propre note. Il vous suffit alors de remplir le champ « Destinataires »
|
||||||
les noms de note que vous voulez créditer, de spécifier le montant et la raison de
|
avec le⋅s nom⋅s de note que vous voulez créditer, de spécifier le montant et la raison
|
||||||
votre transfert, puis de cliquer sur le bouton « Virement ». Après quelques secondes,
|
de votre transfert, puis de cliquer sur le bouton « Virement ». Après quelques secondes,
|
||||||
si votre solde est suffisant et que la transaction est acceptée, un message de
|
si votre solde est suffisant et que la transaction est acceptée, un message de
|
||||||
confirmation apparaîtra et la transaction apparaîtra dans l'historique ci-dessous.
|
confirmation apparaîtra et la transaction apparaîtra dans l'historique ci-dessous.
|
||||||
|
|
||||||
|
@ -49,7 +49,7 @@ Consulter ses données personnelles
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
La Note Kfet sert non seulement à faire des transactions d'argent virtuel au sein
|
La Note Kfet sert non seulement à faire des transactions d'argent virtuel au sein
|
||||||
du BDE, mais aussi à permettre au BDE et à ses clubs de gérer leurs adhérents.
|
du BDE, mais aussi à permettre au BDE et à ses clubs de gérer leurs adhérent⋅es.
|
||||||
À cet effet, diverses informations personnelles sont collectées par la Note.
|
À cet effet, diverses informations personnelles sont collectées par la Note.
|
||||||
|
|
||||||
Pour accéder à votre compte, une fois connecté⋅e, rendez-vous dans le menu en haut
|
Pour accéder à votre compte, une fois connecté⋅e, rendez-vous dans le menu en haut
|
||||||
|
@ -75,26 +75,26 @@ présentes sont :
|
||||||
* Département
|
* Département
|
||||||
* Promotion
|
* Promotion
|
||||||
* Adresse
|
* Adresse
|
||||||
* Élève/étudiant
|
* Élève/étudiant⋅e
|
||||||
* Inscription aux listes de diffusion du BDE, du BDA et du BDS
|
* Inscription aux listes de diffusion du BDE, du BDA et du BDS
|
||||||
|
|
||||||
Les trois premières informations sont obligatoires pour pouvoir vous contacter
|
Les trois premières informations sont obligatoires pour pouvoir vous contacter
|
||||||
et pouvoir tenir un registre d'adhérent.
|
et pouvoir tenir un registre d'adhérent⋅es.
|
||||||
|
|
||||||
Le numéro de téléphone et l'adresse ne sont utilisés uniquement en cas d'urgence,
|
Le numéro de téléphone et l'adresse ne sont utilisés uniquement en cas d'urgence,
|
||||||
notamment en cas de WEI, et ne sont pas des champs obligatoires. De plus,
|
notamment en cas de WEI, et ne sont pas des champs obligatoires. De plus,
|
||||||
promotion, département et section ne sont utilisés sérieusement que en cas
|
promotion, département et section ne sont utilisés sérieusement que en cas
|
||||||
de WEI, et ne sont pas utilisés sinon.
|
de WEI, et ne sont pas utilisés sinon.
|
||||||
|
|
||||||
La distinction élève/étudiant permet de distinguer les achats qui peuvent avoir
|
La distinction élève/étudiant⋅e permet de distinguer les achats qui peuvent avoir
|
||||||
des prix différents pour les élèves et pour les étudiants, notamment en cas de
|
des prix différents pour les élèves et pour les étudiant⋅es, notamment en cas de
|
||||||
transferts d'argent, de WEI ou d'adhésion à certains clubs.
|
transferts d'argent, de WEI ou d'adhésion à certains clubs.
|
||||||
|
|
||||||
Hormis le pseudo, toutes ces informations ont un caractère confidentiel qui les
|
Hormis le pseudo, toutes ces informations ont un caractère confidentiel qui les
|
||||||
rend privées et inaccessible aux utilisateurs. Les trésoriers BDE et les respos
|
rend privées et inaccessible aux utilisateur⋅rices. Les trésorièr⋅es BDE et les respos
|
||||||
info ont accès à toutes les informations (en cas de besoin uniquement, le cas
|
info ont accès à toutes les informations (en cas de besoin uniquement, le cas
|
||||||
contraire est considéré comme de l'abus de droit qui est punissable), et les
|
contraire est considéré comme de l'abus de droit qui est punissable), et les
|
||||||
trésoriers de club ont accès au nom et au prénom afin de faciliter l'association
|
trésorièr⋅es de club ont accès au nom et au prénom afin de faciliter l'association
|
||||||
à un nom de note.
|
à un nom de note.
|
||||||
|
|
||||||
Dans la partie informations personnelles, il est également possible de modifier
|
Dans la partie informations personnelles, il est également possible de modifier
|
||||||
|
@ -106,7 +106,7 @@ de nom de note.
|
||||||
Le tableau des adhésions actives sur la partie du haut contient l'ensemble des
|
Le tableau des adhésions actives sur la partie du haut contient l'ensemble des
|
||||||
clubs auxquels vous êtes adhérent⋅es, avec les dates de début, de fin, votre
|
clubs auxquels vous êtes adhérent⋅es, avec les dates de début, de fin, votre
|
||||||
rôle au sein du club (généralement simple membre, mais cela peut également
|
rôle au sein du club (généralement simple membre, mais cela peut également
|
||||||
être trésorier⋅ère par exemple) ainsi que la cotisation que vous avez éventuellement
|
être trésorièr⋅e par exemple) ainsi que la cotisation que vous avez éventuellement
|
||||||
payée au club.
|
payée au club.
|
||||||
|
|
||||||
L'historique des transactions contient l'ensemble des transactions qui ont fait
|
L'historique des transactions contient l'ensemble des transactions qui ont fait
|
||||||
|
|
|
@ -3,7 +3,7 @@ Documentation de la Note Kfet 2020
|
||||||
|
|
||||||
|
|
||||||
Bienvenue sur la documentation de la Note Kfet 2020. Cette documentation est à la fois
|
Bienvenue sur la documentation de la Note Kfet 2020. Cette documentation est à la fois
|
||||||
destinée aux adhérents BDE pour découvrir le fonctionnement de la note, mais aussi aux
|
destinée aux adhérent⋅es BDE pour découvrir le fonctionnement de la note, mais aussi aux
|
||||||
respos info qui souhaitent découvrir comment fonctionne la note sous le capot.
|
respos info qui souhaitent découvrir comment fonctionne la note sous le capot.
|
||||||
|
|
||||||
Des informations complémentaires sont également disponibles sur le `Wiki Crans <https://wiki.crans.org/NoteKfet/NoteKfet2020/>`_.
|
Des informations complémentaires sont également disponibles sur le `Wiki Crans <https://wiki.crans.org/NoteKfet/NoteKfet2020/>`_.
|
||||||
|
|
|
@ -82,7 +82,7 @@ Pour cela, on peut simplement faire :
|
||||||
$ source env/bin/activate
|
$ source env/bin/activate
|
||||||
(env) $
|
(env) $
|
||||||
|
|
||||||
À noter que ``source`` peut s'abbréger par ``.`` uniquement.
|
À noter que ``source`` peut s'abréger par ``.`` uniquement.
|
||||||
|
|
||||||
Vous êtes donc dans un environnement virtuel Python. Pour installer les dépendances
|
Vous êtes donc dans un environnement virtuel Python. Pour installer les dépendances
|
||||||
de la note :
|
de la note :
|
||||||
|
@ -162,8 +162,8 @@ Ouvrez votre navigateur, tapez `<http://localhost:8000/>`_, enjoy :)
|
||||||
optimisé pour recevoir des requêtes en parallèle ou être utilisé en production.
|
optimisé pour recevoir des requêtes en parallèle ou être utilisé en production.
|
||||||
|
|
||||||
|
|
||||||
Créer un super-utilisateur
|
Créer un⋅e super-utilisateur⋅rice
|
||||||
--------------------------
|
---------------------------------
|
||||||
|
|
||||||
La commande ``./manage.py createsuperuser`` vous permettra de créer un super-utilisateur
|
La commande ``./manage.py createsuperuser`` vous permettra de créer un⋅e
|
||||||
initial.
|
super-utilisateur⋅rice initial⋅e.
|
||||||
|
|
|
@ -15,7 +15,7 @@ version 1.11, qui n'est plus maintenue par Django depuis déjà quelques mois.
|
||||||
Les versions stables de Django sont les versions 2.2 et 3.2, Debian Bullseye
|
Les versions stables de Django sont les versions 2.2 et 3.2, Debian Bullseye
|
||||||
utilisant la version 2.2.
|
utilisant la version 2.2.
|
||||||
|
|
||||||
Afin de permettre à ses utilisateurs d'utiliser les dernières fonctionnalités de
|
Afin de permettre à ses utilisateur⋅rices d'utiliser les dernières fonctionnalités de
|
||||||
certains paquets, Debian a créé une distribution particulière, appelée
|
certains paquets, Debian a créé une distribution particulière, appelée
|
||||||
``buster-backports``. Cette distribution contient des paquets de la distribution
|
``buster-backports``. Cette distribution contient des paquets de la distribution
|
||||||
à venir « ``testing`` » (``bullseye`` à l'heure où cette documentation est écrite)
|
à venir « ``testing`` » (``bullseye`` à l'heure où cette documentation est écrite)
|
||||||
|
@ -187,7 +187,7 @@ clé sous forme de chaîne de caractère suffisamment longue (64 caractères par
|
||||||
qui n'est pas à transmettre et qui évite d'autres sites malveillants de faire des requêtes
|
qui n'est pas à transmettre et qui évite d'autres sites malveillants de faire des requêtes
|
||||||
directement sur la note.
|
directement sur la note.
|
||||||
|
|
||||||
Le champ ``CONTACT_EMAIL`` correspond l'adresse mail que les adhérent⋅e⋅s peuvent contacter
|
Le champ ``CONTACT_EMAIL`` correspond l'adresse mail que les adhérent⋅es peuvent contacter
|
||||||
en cas de problème. C'est là où le champ ``Nous contacter`` redirigera.
|
en cas de problème. C'est là où le champ ``Nous contacter`` redirigera.
|
||||||
|
|
||||||
Le champ ``NOTE_URL`` correspond au nom de domaine autorisé à accéder au site. C'est également
|
Le champ ``NOTE_URL`` correspond au nom de domaine autorisé à accéder au site. C'est également
|
||||||
|
@ -636,5 +636,5 @@ On peut enfin redémarrer le serveur Web. Les données ont bien été copiées.
|
||||||
|
|
||||||
.. caution::
|
.. caution::
|
||||||
|
|
||||||
On ne copiera **jamais** des données d'adhérent⋅e⋅s sur une machine personnelle.
|
On ne copiera **jamais** des données d'adhérent⋅es sur une machine personnelle.
|
||||||
Ce type d'opération doit s'effectuer impérativement entre des serveurs du BDE.
|
Ce type d'opération doit s'effectuer impérativement entre des serveurs du BDE.
|
||||||
|
|
|
@ -139,8 +139,8 @@ de diffusion utiles.
|
||||||
Il prend 2 options :
|
Il prend 2 options :
|
||||||
|
|
||||||
* ``--type``, qui prend en argument ``members`` (défaut), ``clubs``, ``events``, ``art``,
|
* ``--type``, qui prend en argument ``members`` (défaut), ``clubs``, ``events``, ``art``,
|
||||||
``sport``, qui permet respectivement de sortir la liste des adresses mails des adhérents
|
``sport``, qui permet respectivement de sortir la liste des adresses mails des adhérent⋅es
|
||||||
actuels (pour la liste ``adherents.bde@lists.crans.org), des clubs (pour
|
actuel⋅les (pour la liste ``adherents.bde@lists.crans.org), des clubs (pour
|
||||||
``clubs@lists.crans.org``), des personnes à abonner à ``evenements@lists.crans.org``,
|
``clubs@lists.crans.org``), des personnes à abonner à ``evenements@lists.crans.org``,
|
||||||
à ``all.bda@lists.crans.org`` et enfin à ``bds@lists.crans.org``.
|
à ``all.bda@lists.crans.org`` et enfin à ``bds@lists.crans.org``.
|
||||||
* ``--lang``, qui prend en argument ``fr`` ou ``en``. N'est utile que pour la ML événements,
|
* ``--lang``, qui prend en argument ``fr`` ou ``en``. N'est utile que pour la ML événements,
|
||||||
|
@ -157,8 +157,8 @@ malheureusement pas aussi simple que de simplement supposer que ces listes sont
|
||||||
À terme, il pourrait être envisageable de synchroniser automatiquement les listes avec la note.
|
À terme, il pourrait être envisageable de synchroniser automatiquement les listes avec la note.
|
||||||
|
|
||||||
|
|
||||||
Suppression d'un utilisateur
|
Suppression d'un⋅e utilisateur⋅rice
|
||||||
----------------------------
|
-----------------------------------
|
||||||
|
|
||||||
Le script s'appelle ``force_delete_user``.
|
Le script s'appelle ``force_delete_user``.
|
||||||
|
|
||||||
|
@ -167,7 +167,7 @@ Le script s'appelle ``force_delete_user``.
|
||||||
Ce script est dangereux. À n'utiliser qu'avec de très grosses pincettes si vous savez
|
Ce script est dangereux. À n'utiliser qu'avec de très grosses pincettes si vous savez
|
||||||
ce que vous faites. Seul cas d'usage pour l'instant recensé : supprimer des comptes en
|
ce que vous faites. Seul cas d'usage pour l'instant recensé : supprimer des comptes en
|
||||||
double qui se sont malencontreusement retrouvés validés pour raison de Sogé et de mauvaise
|
double qui se sont malencontreusement retrouvés validés pour raison de Sogé et de mauvaise
|
||||||
communication au sein des trésorier⋅ère⋅s.
|
communication au sein des trésorièr⋅es.
|
||||||
|
|
||||||
Il n'est certainement pas prévu de supprimer des vrais comptes existants via ce script.
|
Il n'est certainement pas prévu de supprimer des vrais comptes existants via ce script.
|
||||||
On ne supprime pas l'historique. Si jamais quelqu'un demanderait à supprimer son compte,
|
On ne supprime pas l'historique. Si jamais quelqu'un demanderait à supprimer son compte,
|
||||||
|
@ -175,8 +175,8 @@ Le script s'appelle ``force_delete_user``.
|
||||||
|
|
||||||
Ce script est utile lorsqu'il faut supprimer un compte créer par erreur. Tant que la validation
|
Ce script est utile lorsqu'il faut supprimer un compte créer par erreur. Tant que la validation
|
||||||
n'est pas faite, il suffit en général de cliquer sur le bouton « Supprimer le compte » sur
|
n'est pas faite, il suffit en général de cliquer sur le bouton « Supprimer le compte » sur
|
||||||
l'interface de validation. Cela supprimera l'utilisateur et le profil associé, sans toucher
|
l'interface de validation. Cela supprimera l'utilisateur⋅rice et le profil associé, sans
|
||||||
à une quelconque note puisqu'elle ne sera pas créée.
|
toucher à une quelconque note puisqu'elle ne sera pas créée.
|
||||||
|
|
||||||
Ce script supprime donc un compte ainsi que toutes les données associées (note, alias,
|
Ce script supprime donc un compte ainsi que toutes les données associées (note, alias,
|
||||||
transactions). Il n'est donc pas à prendre à la légère, et vous devez savoir ce que vous
|
transactions). Il n'est donc pas à prendre à la légère, et vous devez savoir ce que vous
|
||||||
|
@ -192,8 +192,8 @@ pour supprimer tout ce qu'il faut, et une validation manuelle sera requise pour
|
||||||
la suppression. L'option ``--doit`` évite cette confirmation manuelle.
|
la suppression. L'option ``--doit`` évite cette confirmation manuelle.
|
||||||
**Vous n'avez jamais à utiliser cette option en théorie.**
|
**Vous n'avez jamais à utiliser cette option en théorie.**
|
||||||
|
|
||||||
À la fin du processus, un mail est envoyé aux administrateurs pour les prévenir des
|
À la fin du processus, un mail est envoyé aux administrateur⋅rices pour les prévenir des
|
||||||
élements supprimés.
|
éléments supprimés.
|
||||||
|
|
||||||
Des données réelles jamais tu ne supprimeras.
|
Des données réelles jamais tu ne supprimeras.
|
||||||
|
|
||||||
|
@ -210,18 +210,18 @@ la Note Kfet 2015.
|
||||||
s'est déroulé.
|
s'est déroulé.
|
||||||
|
|
||||||
|
|
||||||
Ajouter un super-utilisateur
|
Ajouter un⋅e super-utilisateur⋅rice
|
||||||
----------------------------
|
-----------------------------------
|
||||||
|
|
||||||
Le script s'appelle ``make_su``.
|
Le script s'appelle ``make_su``.
|
||||||
|
|
||||||
Il prend en argument un pseudo.
|
Il prend en argument un pseudo.
|
||||||
|
|
||||||
Avec l'option ``--SUPER, -S``, la personne avec ce pseudo devient super-utilisateur,
|
Avec l'option ``--SUPER, -S``, la personne avec ce pseudo devient super-utilisateur⋅rice,
|
||||||
et obtiens donc les pleins pouvoirs sur la note. À ne donner qu'aux respos info.
|
et obtiens donc les pleins pouvoirs sur la note. À ne donner qu'aux respos info.
|
||||||
|
|
||||||
Avec l'option ``--STAFF, -s``, la personne avec ce pseudo acquiert le statut équipe,
|
Avec l'option ``--STAFF, -s``, la personne avec ce pseudo acquiert le statut équipe,
|
||||||
et obtiens l'accès à django-admin. À ne donner qu'aux respos info.
|
et obtient l'accès à django-admin. À ne donner qu'aux respos info.
|
||||||
|
|
||||||
|
|
||||||
Rafraîchissement des activités
|
Rafraîchissement des activités
|
||||||
|
@ -264,20 +264,20 @@ Envoi des rappels de négatif
|
||||||
|
|
||||||
Le script s'appelle ``send_mail_to_negative_balances``.
|
Le script s'appelle ``send_mail_to_negative_balances``.
|
||||||
|
|
||||||
Il sert à rappeler aux adhérent⋅e⋅s et clubs en négatif qu'ils le sont, mais également
|
Il sert à rappeler aux adhérent⋅es et clubs en négatif qui le sont, mais également
|
||||||
à envoyer aux trésorier⋅ère⋅s et respos info la liste des adhérent⋅e⋅s en négatif.
|
à envoyer aux trésorièr⋅es et respos info la liste des adhérent⋅es en négatif.
|
||||||
|
|
||||||
Il prend les options suivantes :
|
Il prend les options suivantes :
|
||||||
|
|
||||||
* ``--spam, -s`` : envoie à chaque adhérent⋅e en négatif un rappel par mail pour recharger
|
* ``--spam, -s`` : envoie à chaque adhérent⋅e en négatif un rappel par mail pour recharger
|
||||||
* ``--report, -r`` : envoie le rapport aux trésorier⋅ère⋅s et respos info
|
* ``--report, -r`` : envoie le rapport aux trésorièr⋅es et respos info
|
||||||
* ``--negative-amount,-n`` : définit le solde maximal en-dessous duquel les notes
|
* ``--negative-amount,-n`` : définit le solde maximal en-dessous duquel les notes
|
||||||
apparaitront sur le rapport / seront spammées
|
apparaitront sur le rapport / seront spammées
|
||||||
* ``--add-years, -y`` : ajoute également les adhérent⋅e⋅s des ``n`` dernières années
|
* ``--add-years, -y`` : ajoute également les adhérent⋅es des ``n`` dernières années
|
||||||
|
|
||||||
Ce script est appelé tous les mardis à 5h00 pour spammer les utilisateur⋅rice⋅s en
|
Ce script est appelé tous les mardis à 5h00 pour spammer les utilisateur⋅ices en
|
||||||
négatif et tous les 6 du mois pour envoyer le rapport des notes d'adhérent⋅e⋅s ou de
|
négatif et tous les 6 du mois pour envoyer le rapport des notes d'adhérent⋅es ou de
|
||||||
vieux/vieilles adhérent⋅e⋅s de moins d'un an sous -10 €.
|
vieilleux adhérent⋅es de moins d'un an sous -10 €.
|
||||||
|
|
||||||
|
|
||||||
Envoi des rapports
|
Envoi des rapports
|
||||||
|
@ -285,8 +285,8 @@ Envoi des rapports
|
||||||
|
|
||||||
Le script s'appelle ``send_reports``.
|
Le script s'appelle ``send_reports``.
|
||||||
|
|
||||||
Les utilisateurs ont la possibilité de recevoir sur demande un rapport à la fréquence de
|
Les utilisateur⋅rices ont la possibilité de recevoir sur demande un rapport à la
|
||||||
leur choix (en jours) des transactions effectuées sur leur note.
|
fréquence de leur choix (en jours) des transactions effectuées sur leur note.
|
||||||
|
|
||||||
Le script prend 2 options :
|
Le script prend 2 options :
|
||||||
|
|
||||||
|
|
|
@ -1446,8 +1446,10 @@ msgid "trusted"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: apps/note/models/notes.py:243
|
#: apps/note/models/notes.py:243
|
||||||
msgid "frienship"
|
#, fuzzy
|
||||||
msgstr ""
|
#| msgid "Manage aliases"
|
||||||
|
msgid "friendship"
|
||||||
|
msgstr "Aliases bearbeiten"
|
||||||
|
|
||||||
#: apps/note/models/notes.py:248
|
#: apps/note/models/notes.py:248
|
||||||
#, python-brace-format
|
#, python-brace-format
|
||||||
|
|
|
@ -9,9 +9,9 @@ msgstr ""
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2022-10-07 09:07+0200\n"
|
"POT-Creation-Date: 2022-10-07 09:07+0200\n"
|
||||||
"PO-Revision-Date: 2020-11-16 20:21+0000\n"
|
"PO-Revision-Date: 2020-11-16 20:21+0000\n"
|
||||||
"Last-Translator: Yohann D'ANELLO <ynerant@crans.org>\n"
|
"Last-Translator: Emmy D'ANELLO <ynerant@crans.org>\n"
|
||||||
"Language-Team: German <http://translate.ynerant.fr/projects/nk20/nk20-js/de/"
|
"Language-Team: German <http://translate.ynerant.fr/projects/nk20/nk20-js/de/>"
|
||||||
">\n"
|
"\n"
|
||||||
"Language: de\n"
|
"Language: de\n"
|
||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
"Content-Type: text/plain; charset=UTF-8\n"
|
"Content-Type: text/plain; charset=UTF-8\n"
|
||||||
|
|
|
@ -1433,8 +1433,10 @@ msgid "trusted"
|
||||||
msgstr "amigo"
|
msgstr "amigo"
|
||||||
|
|
||||||
#: apps/note/models/notes.py:243
|
#: apps/note/models/notes.py:243
|
||||||
msgid "frienship"
|
#, fuzzy
|
||||||
msgstr "amistad"
|
#| msgid "friendships"
|
||||||
|
msgid "friendship"
|
||||||
|
msgstr "amistades"
|
||||||
|
|
||||||
#: apps/note/models/notes.py:248
|
#: apps/note/models/notes.py:248
|
||||||
#, python-brace-format
|
#, python-brace-format
|
||||||
|
|
|
@ -82,7 +82,7 @@ msgstr "peut inviter"
|
||||||
#: apps/activity/models.py:44
|
#: apps/activity/models.py:44
|
||||||
#: apps/activity/templates/activity/includes/activity_info.html:46
|
#: apps/activity/templates/activity/includes/activity_info.html:46
|
||||||
msgid "guest entry fee"
|
msgid "guest entry fee"
|
||||||
msgstr "cotisation de l'entrée invitée"
|
msgstr "cotisation de l'entrée invité⋅e"
|
||||||
|
|
||||||
#: apps/activity/models.py:49
|
#: apps/activity/models.py:49
|
||||||
msgid "activity type"
|
msgid "activity type"
|
||||||
|
@ -119,12 +119,12 @@ msgstr "type"
|
||||||
#: apps/wei/models.py:171 apps/wei/templates/wei/attribute_bus_1A.html:13
|
#: apps/wei/models.py:171 apps/wei/templates/wei/attribute_bus_1A.html:13
|
||||||
#: apps/wei/templates/wei/survey.html:15
|
#: apps/wei/templates/wei/survey.html:15
|
||||||
msgid "user"
|
msgid "user"
|
||||||
msgstr "utilisateur·ice"
|
msgstr "utilisateur⋅rice"
|
||||||
|
|
||||||
#: apps/activity/models.py:96
|
#: apps/activity/models.py:96
|
||||||
#: apps/activity/templates/activity/includes/activity_info.html:36
|
#: apps/activity/templates/activity/includes/activity_info.html:36
|
||||||
msgid "organizer"
|
msgid "organizer"
|
||||||
msgstr "organisateur·ice"
|
msgstr "organisateur·rice"
|
||||||
|
|
||||||
#: apps/activity/models.py:97
|
#: apps/activity/models.py:97
|
||||||
msgid "Club that organizes the activity. The entry fees will go to this club."
|
msgid "Club that organizes the activity. The entry fees will go to this club."
|
||||||
|
@ -366,7 +366,7 @@ msgstr "Toutes les activités"
|
||||||
|
|
||||||
#: apps/activity/templates/activity/includes/activity_info.html:32
|
#: apps/activity/templates/activity/includes/activity_info.html:32
|
||||||
msgid "creater"
|
msgid "creater"
|
||||||
msgstr "créateur·ice"
|
msgstr "créateur⋅rice"
|
||||||
|
|
||||||
#: apps/activity/templates/activity/includes/activity_info.html:53
|
#: apps/activity/templates/activity/includes/activity_info.html:53
|
||||||
msgid "opened"
|
msgid "opened"
|
||||||
|
@ -588,7 +588,7 @@ msgstr "Pas de rechargement"
|
||||||
|
|
||||||
#: apps/member/forms.py:185
|
#: apps/member/forms.py:185
|
||||||
msgid "You can credit the note of the user."
|
msgid "You can credit the note of the user."
|
||||||
msgstr "Vous pouvez créditer la note de l'utilisateur·ice avant l'adhésion."
|
msgstr "Vous pouvez créditer la note de l'utilisateur⋅rice avant l'adhésion."
|
||||||
|
|
||||||
#: apps/member/forms.py:186 apps/registration/forms.py:85
|
#: apps/member/forms.py:186 apps/registration/forms.py:85
|
||||||
#: apps/wei/forms/registration.py:97
|
#: apps/wei/forms/registration.py:97
|
||||||
|
@ -603,7 +603,7 @@ msgstr "Banque"
|
||||||
|
|
||||||
#: apps/member/forms.py:233
|
#: apps/member/forms.py:233
|
||||||
msgid "User"
|
msgid "User"
|
||||||
msgstr "Utilisateur·ice"
|
msgstr "Utilisateur⋅rice"
|
||||||
|
|
||||||
#: apps/member/forms.py:247
|
#: apps/member/forms.py:247
|
||||||
msgid "Roles"
|
msgid "Roles"
|
||||||
|
@ -732,11 +732,11 @@ msgstr "adresse"
|
||||||
#: apps/registration/templates/registration/future_profile_detail.html:43
|
#: apps/registration/templates/registration/future_profile_detail.html:43
|
||||||
#: apps/wei/templates/wei/weimembership_form.html:47
|
#: apps/wei/templates/wei/weimembership_form.html:47
|
||||||
msgid "paid"
|
msgid "paid"
|
||||||
msgstr "payé·e"
|
msgstr "payé⋅e"
|
||||||
|
|
||||||
#: apps/member/models.py:90
|
#: apps/member/models.py:90
|
||||||
msgid "Tells if the user receive a salary."
|
msgid "Tells if the user receive a salary."
|
||||||
msgstr "Indique si l'utilisateur·ice perçoit un salaire."
|
msgstr "Indique si l'utilisateur⋅rice perçoit un salaire."
|
||||||
|
|
||||||
#: apps/member/models.py:99 apps/treasury/tables.py:143
|
#: apps/member/models.py:99 apps/treasury/tables.py:143
|
||||||
msgid "No"
|
msgid "No"
|
||||||
|
@ -763,7 +763,6 @@ msgid ""
|
||||||
"Register on the mailing list to stay informed of the sport events of the "
|
"Register on the mailing list to stay informed of the sport events of the "
|
||||||
"campus (1 mail/week)"
|
"campus (1 mail/week)"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"S'inscrire sur la liste de diffusion pour rester informé·e des actualités "
|
|
||||||
"sportives sur le campus (1 mail par semaine)"
|
"sportives sur le campus (1 mail par semaine)"
|
||||||
|
|
||||||
#: apps/member/models.py:113
|
#: apps/member/models.py:113
|
||||||
|
@ -784,7 +783,7 @@ msgstr "date de dernier rapport"
|
||||||
|
|
||||||
#: apps/member/models.py:127
|
#: apps/member/models.py:127
|
||||||
msgid "email confirmed"
|
msgid "email confirmed"
|
||||||
msgstr "adresse email confirmée"
|
msgstr "adresse e-mail confirmée"
|
||||||
|
|
||||||
#: apps/member/models.py:132
|
#: apps/member/models.py:132
|
||||||
msgid "registration valid"
|
msgid "registration valid"
|
||||||
|
@ -796,7 +795,7 @@ msgstr "Charte VSS lue"
|
||||||
|
|
||||||
#: apps/member/models.py:142 apps/member/models.py:143
|
#: apps/member/models.py:142 apps/member/models.py:143
|
||||||
msgid "user profile"
|
msgid "user profile"
|
||||||
msgstr "profil utilisateur·ice"
|
msgstr "profil utilisateur·rice"
|
||||||
|
|
||||||
#: apps/member/models.py:177
|
#: apps/member/models.py:177
|
||||||
msgid "Activate your Note Kfet account"
|
msgid "Activate your Note Kfet account"
|
||||||
|
@ -894,11 +893,11 @@ msgstr "Le rôle {role} ne s'applique pas au club {club}."
|
||||||
|
|
||||||
#: apps/member/models.py:381 apps/member/views.py:712
|
#: apps/member/models.py:381 apps/member/views.py:712
|
||||||
msgid "User is already a member of the club"
|
msgid "User is already a member of the club"
|
||||||
msgstr "L'utilisateur·ice est déjà membre du club"
|
msgstr "L'utilisateur·rice est déjà membre du club"
|
||||||
|
|
||||||
#: apps/member/models.py:393 apps/member/views.py:721
|
#: apps/member/models.py:393 apps/member/views.py:721
|
||||||
msgid "User is not a member of the parent club"
|
msgid "User is not a member of the parent club"
|
||||||
msgstr "L'utilisateur·ice n'est pas membre du club parent"
|
msgstr "L'utilisateur·rice n'est pas membre du club parent"
|
||||||
|
|
||||||
#: apps/member/tables.py:139
|
#: apps/member/tables.py:139
|
||||||
msgid "Renew"
|
msgid "Renew"
|
||||||
|
@ -911,7 +910,7 @@ msgid ""
|
||||||
"%(pretty_fee)s will be charged to renew automatically the membership in this/"
|
"%(pretty_fee)s will be charged to renew automatically the membership in this/"
|
||||||
"these club·s."
|
"these club·s."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Cet·te utilisateur·ice n'est pas membre du/des club·s parent·s %(clubs)s. Un "
|
"Cet·te utilisateur·rice n'est pas membre du/des club·s parent·s %(clubs)s. Un "
|
||||||
"montant supplémentaire de %(pretty_fee)s sera débité afin de renouveler "
|
"montant supplémentaire de %(pretty_fee)s sera débité afin de renouveler "
|
||||||
"automatiquement l'adhésion dans ce·s club·s."
|
"automatiquement l'adhésion dans ce·s club·s."
|
||||||
|
|
||||||
|
@ -921,8 +920,8 @@ msgid ""
|
||||||
"The user is not a member of the club·s %(clubs)s. Please create the required "
|
"The user is not a member of the club·s %(clubs)s. Please create the required "
|
||||||
"memberships, otherwise it will fail."
|
"memberships, otherwise it will fail."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Cet·te utilisateur·ice n'est pas membre du/des club·s parent·s %(clubs)s. Merci de "
|
"Cet⋅te utilisateur⋅rice n'est pas membre du/des club·s parent·s %(clubs)s. "
|
||||||
"d'abord créer l'adhésion requise, sinon cette adhésion va échouer."
|
"Merci de d'abord créer l'adhésion requise, sinon cette adhésion va échouer."
|
||||||
|
|
||||||
#: apps/member/templates/member/add_members.html:29
|
#: apps/member/templates/member/add_members.html:29
|
||||||
#, python-format
|
#, python-format
|
||||||
|
@ -939,7 +938,7 @@ msgid ""
|
||||||
"This club has parents %(clubs)s. Please make sure that the user is a member "
|
"This club has parents %(clubs)s. Please make sure that the user is a member "
|
||||||
"of this or these club·s, otherwise the creation of this membership will fail."
|
"of this or these club·s, otherwise the creation of this membership will fail."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Ce club a pour parents %(clubs)s. Merci de vous assurer que l'utilisateur·ice "
|
"Ce club a pour parents %(clubs)s. Merci de vous assurer que l'utilisateur⋅rice "
|
||||||
"est membre de ce·s club·s, sinon la création de cette adhésion va échouer."
|
"est membre de ce·s club·s, sinon la création de cette adhésion va échouer."
|
||||||
|
|
||||||
#: apps/member/templates/member/base.html:17
|
#: apps/member/templates/member/base.html:17
|
||||||
|
@ -988,8 +987,8 @@ msgid ""
|
||||||
"If you use the force mode, the user won't be able to unlock the note by "
|
"If you use the force mode, the user won't be able to unlock the note by "
|
||||||
"itself."
|
"itself."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Si vous verrouillez la note de force, l'utilisateur·ice ne pourra plus la "
|
"Si vous verrouillez la note de force, l'utilisateur⋅rice ne pourra plus la "
|
||||||
"déverrouiller soi-même."
|
"déverrouiller ellui-même."
|
||||||
|
|
||||||
#: apps/member/templates/member/base.html:110
|
#: apps/member/templates/member/base.html:110
|
||||||
#: apps/member/templates/member/base.html:137 apps/treasury/forms.py:91
|
#: apps/member/templates/member/base.html:137 apps/treasury/forms.py:91
|
||||||
|
@ -1132,7 +1131,7 @@ msgstr "Attention"
|
||||||
|
|
||||||
#: apps/member/templates/member/manage_auth_tokens.html:44
|
#: apps/member/templates/member/manage_auth_tokens.html:44
|
||||||
msgid "Regenerate token"
|
msgid "Regenerate token"
|
||||||
msgstr "Regénérer le jeton"
|
msgstr "Régénérer le jeton"
|
||||||
|
|
||||||
#: apps/member/templates/member/manage_auth_tokens.html:53
|
#: apps/member/templates/member/manage_auth_tokens.html:53
|
||||||
msgid "OAuth2 authentication"
|
msgid "OAuth2 authentication"
|
||||||
|
@ -1170,7 +1169,7 @@ msgstr "Recadrer et envoyer"
|
||||||
#: apps/registration/templates/registration/future_profile_detail.html:28
|
#: apps/registration/templates/registration/future_profile_detail.html:28
|
||||||
#: apps/wei/templates/wei/weimembership_form.html:26
|
#: apps/wei/templates/wei/weimembership_form.html:26
|
||||||
msgid "This user doesn't have confirmed his/her e-mail address."
|
msgid "This user doesn't have confirmed his/her e-mail address."
|
||||||
msgstr "Cet·te utilisateur·ice n'a pas encore confirmé son adresse e-mail."
|
msgstr "Cet⋅te utilisateur⋅rice n'a pas encore confirmé son adresse e-mail."
|
||||||
|
|
||||||
#: apps/member/templates/member/profile_detail.html:13
|
#: apps/member/templates/member/profile_detail.html:13
|
||||||
#: apps/registration/templates/registration/future_profile_detail.html:29
|
#: apps/registration/templates/registration/future_profile_detail.html:29
|
||||||
|
@ -1217,11 +1216,11 @@ msgstr "Cette adresse doit être valide."
|
||||||
|
|
||||||
#: apps/member/views.py:139
|
#: apps/member/views.py:139
|
||||||
msgid "Profile detail"
|
msgid "Profile detail"
|
||||||
msgstr "Détails de l'utilisateur·ice"
|
msgstr "Détails de l'utilisateur⋅rice"
|
||||||
|
|
||||||
#: apps/member/views.py:205
|
#: apps/member/views.py:205
|
||||||
msgid "Search user"
|
msgid "Search user"
|
||||||
msgstr "Chercher un·e utilisateur·ice"
|
msgstr "Chercher un·e utilisateur·rice"
|
||||||
|
|
||||||
#: apps/member/views.py:253
|
#: apps/member/views.py:253
|
||||||
msgid "Note friendships"
|
msgid "Note friendships"
|
||||||
|
@ -1253,15 +1252,15 @@ msgstr "Modifier le club"
|
||||||
|
|
||||||
#: apps/member/views.py:574
|
#: apps/member/views.py:574
|
||||||
msgid "Add new member to the club"
|
msgid "Add new member to the club"
|
||||||
msgstr "Ajouter un·e nouvelle·au membre au club"
|
msgstr "Ajouter un·e nouvelleau membre au club"
|
||||||
|
|
||||||
#: apps/member/views.py:703 apps/wei/views.py:973
|
#: apps/member/views.py:703 apps/wei/views.py:973
|
||||||
msgid ""
|
msgid ""
|
||||||
"This user don't have enough money to join this club, and can't have a "
|
"This user don't have enough money to join this club, and can't have a "
|
||||||
"negative balance."
|
"negative balance."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Cet·te utilisateur·ice n'a pas assez d'argent pour rejoindre ce club et ne peut pas "
|
"Cet⋅te utilisateur⋅rice n'a pas assez d'argent pour rejoindre ce club et ne "
|
||||||
"avoir un solde négatif."
|
"peut pas avoir un solde négatif."
|
||||||
|
|
||||||
#: apps/member/views.py:725
|
#: apps/member/views.py:725
|
||||||
msgid "The membership must start after {:%m-%d-%Y}."
|
msgid "The membership must start after {:%m-%d-%Y}."
|
||||||
|
@ -1273,7 +1272,7 @@ msgstr "L'adhésion doit commencer avant le {:%d/%m/%Y}."
|
||||||
|
|
||||||
#: apps/member/views.py:880
|
#: apps/member/views.py:880
|
||||||
msgid "Manage roles of an user in the club"
|
msgid "Manage roles of an user in the club"
|
||||||
msgstr "Gérer les rôles d'un·e utilisateur·ice dans le club"
|
msgstr "Gérer les rôles d'un⋅e utilisateur⋅rice dans le club"
|
||||||
|
|
||||||
#: apps/member/views.py:905
|
#: apps/member/views.py:905
|
||||||
msgid "Members of the club"
|
msgid "Members of the club"
|
||||||
|
@ -1384,8 +1383,8 @@ msgstr ""
|
||||||
#: apps/note/models/notes.py:70
|
#: apps/note/models/notes.py:70
|
||||||
msgid "The note is blocked by the the BDE and can't be manually reactivated."
|
msgid "The note is blocked by the the BDE and can't be manually reactivated."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"La note est bloquée de force par le BDE et ne peut pas être débloquée par le·a "
|
"La note est bloquée de force par le BDE et ne peut pas être débloquée par læ "
|
||||||
"possesseur·ice de la note."
|
"propriétaire de la note."
|
||||||
|
|
||||||
#: apps/note/models/notes.py:78
|
#: apps/note/models/notes.py:78
|
||||||
msgid "notes"
|
msgid "notes"
|
||||||
|
@ -1397,11 +1396,11 @@ msgstr "Cet alias est déjà pris."
|
||||||
|
|
||||||
#: apps/note/models/notes.py:152
|
#: apps/note/models/notes.py:152
|
||||||
msgid "one's note"
|
msgid "one's note"
|
||||||
msgstr "note d'un·e utilisateur·ice"
|
msgstr "note d'un·e utilisateur·rice"
|
||||||
|
|
||||||
#: apps/note/models/notes.py:153
|
#: apps/note/models/notes.py:153
|
||||||
msgid "users note"
|
msgid "users note"
|
||||||
msgstr "notes des utilisateur·ice·s"
|
msgstr "notes des utilisateur·rice·s"
|
||||||
|
|
||||||
#: apps/note/models/notes.py:159
|
#: apps/note/models/notes.py:159
|
||||||
#, python-format
|
#, python-format
|
||||||
|
@ -1438,7 +1437,7 @@ msgid "trusted"
|
||||||
msgstr "ami·e"
|
msgstr "ami·e"
|
||||||
|
|
||||||
#: apps/note/models/notes.py:243
|
#: apps/note/models/notes.py:243
|
||||||
msgid "frienship"
|
msgid "friendship"
|
||||||
msgstr "amitié"
|
msgstr "amitié"
|
||||||
|
|
||||||
#: apps/note/models/notes.py:248
|
#: apps/note/models/notes.py:248
|
||||||
|
@ -1543,7 +1542,7 @@ msgid ""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Les montants des notes doivent se trouver entre - 92 233 720 368 547 758.08 "
|
"Les montants des notes doivent se trouver entre - 92 233 720 368 547 758.08 "
|
||||||
"€ et 92 233 720 368 547 758.07 €. Ne cherchez pas à capitaliser l'argent du "
|
"€ et 92 233 720 368 547 758.07 €. Ne cherchez pas à capitaliser l'argent du "
|
||||||
"BDE."
|
"BDE, il est temps de penser à partager les richesses."
|
||||||
|
|
||||||
#: apps/note/models/transactions.py:274
|
#: apps/note/models/transactions.py:274
|
||||||
msgid "recurrent transaction"
|
msgid "recurrent transaction"
|
||||||
|
@ -1558,7 +1557,7 @@ msgid ""
|
||||||
"The destination of this transaction must equal to the destination of the "
|
"The destination of this transaction must equal to the destination of the "
|
||||||
"template."
|
"template."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Le·a destinataire de cette transaction doit être identique à celui du bouton "
|
"Læ destinataire de cette transaction doit être identique à cellui du bouton "
|
||||||
"utilisé."
|
"utilisé."
|
||||||
|
|
||||||
#: apps/note/models/transactions.py:290
|
#: apps/note/models/transactions.py:290
|
||||||
|
@ -1587,7 +1586,7 @@ msgid ""
|
||||||
"payment method and a User or a Club"
|
"payment method and a User or a Club"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Une transaction spéciale n'est possible que entre une note associée à un "
|
"Une transaction spéciale n'est possible que entre une note associée à un "
|
||||||
"mode de paiement et un·e utilisateur·ice ou un club"
|
"mode de paiement et un⋅e utilisateur⋅rice ou un club"
|
||||||
|
|
||||||
#: apps/note/models/transactions.py:357 apps/note/models/transactions.py:360
|
#: apps/note/models/transactions.py:357 apps/note/models/transactions.py:360
|
||||||
#: apps/note/models/transactions.py:363 apps/wei/views.py:978
|
#: apps/note/models/transactions.py:363 apps/wei/views.py:978
|
||||||
|
@ -1661,8 +1660,8 @@ msgstr "Consommer"
|
||||||
#: apps/note/templates/note/conso_form.html:43
|
#: apps/note/templates/note/conso_form.html:43
|
||||||
#: apps/note/templates/note/transaction_form.html:69
|
#: apps/note/templates/note/transaction_form.html:69
|
||||||
#: apps/note/templates/note/transaction_form.html:96
|
#: apps/note/templates/note/transaction_form.html:96
|
||||||
msgid "Name or alias..."
|
msgid "Name or alias…"
|
||||||
msgstr "Pseudo ou alias ..."
|
msgstr "Pseudo ou alias…"
|
||||||
|
|
||||||
#: apps/note/templates/note/conso_form.html:53
|
#: apps/note/templates/note/conso_form.html:53
|
||||||
msgid "Select consumptions"
|
msgid "Select consumptions"
|
||||||
|
@ -1711,11 +1710,11 @@ msgstr "Mail généré par la Note Kfet le"
|
||||||
#: apps/note/templates/note/transaction_form.html:58
|
#: apps/note/templates/note/transaction_form.html:58
|
||||||
#: apps/note/templates/note/transaction_form.html:178
|
#: apps/note/templates/note/transaction_form.html:178
|
||||||
msgid "Select emitters"
|
msgid "Select emitters"
|
||||||
msgstr "Sélection des émetteur·ice·s"
|
msgstr "Sélection des émetteur·rice·s"
|
||||||
|
|
||||||
#: apps/note/templates/note/transaction_form.html:73
|
#: apps/note/templates/note/transaction_form.html:73
|
||||||
msgid "I am the emitter"
|
msgid "I am the emitter"
|
||||||
msgstr "Je suis l'émetteur·ice"
|
msgstr "Je suis l'émetteur⋅rice"
|
||||||
|
|
||||||
#: apps/note/templates/note/transaction_form.html:85
|
#: apps/note/templates/note/transaction_form.html:85
|
||||||
#: apps/note/templates/note/transaction_form.html:180
|
#: apps/note/templates/note/transaction_form.html:180
|
||||||
|
@ -1740,11 +1739,11 @@ msgstr "Nom"
|
||||||
|
|
||||||
#: apps/note/templates/note/transaction_form.html:177
|
#: apps/note/templates/note/transaction_form.html:177
|
||||||
msgid "Select emitter"
|
msgid "Select emitter"
|
||||||
msgstr "Sélection de l'émetteur·ice"
|
msgstr "Sélection de l'émetteur⋅rice"
|
||||||
|
|
||||||
#: apps/note/templates/note/transaction_form.html:179
|
#: apps/note/templates/note/transaction_form.html:179
|
||||||
msgid "Select receiver"
|
msgid "Select receiver"
|
||||||
msgstr "Sélection du destinataire"
|
msgstr "Sélection de læ destinataire"
|
||||||
|
|
||||||
#: apps/note/templates/note/transaction_form.html:181
|
#: apps/note/templates/note/transaction_form.html:181
|
||||||
msgid "Transfer type"
|
msgid "Transfer type"
|
||||||
|
@ -1767,24 +1766,24 @@ msgid "Current price"
|
||||||
msgstr "Prix actuel"
|
msgstr "Prix actuel"
|
||||||
|
|
||||||
#: apps/note/templates/note/transactiontemplate_list.html:13
|
#: apps/note/templates/note/transactiontemplate_list.html:13
|
||||||
msgid "Name of the button..."
|
msgid "Name of the button…"
|
||||||
msgstr "Nom du bouton ..."
|
msgstr "Nom du bouton…"
|
||||||
|
|
||||||
#: apps/note/templates/note/transactiontemplate_list.html:15
|
#: apps/note/templates/note/transactiontemplate_list.html:15
|
||||||
msgid "New button"
|
msgid "New button"
|
||||||
msgstr "Nouveau bouton"
|
msgstr "Nouveau bouton"
|
||||||
|
|
||||||
#: apps/note/templates/note/transactiontemplate_list.html:22
|
#: apps/note/templates/note/transactiontemplate_list.html:22
|
||||||
msgid "buttons listing "
|
msgid "buttons listing"
|
||||||
msgstr "liste des boutons "
|
msgstr "liste des boutons"
|
||||||
|
|
||||||
#: apps/note/templates/note/transactiontemplate_list.html:73
|
#: apps/note/templates/note/transactiontemplate_list.html:73
|
||||||
msgid "button successfully deleted "
|
msgid "button successfully deleted"
|
||||||
msgstr "le bouton a bien été supprimé "
|
msgstr "le bouton a bien été supprimé"
|
||||||
|
|
||||||
#: apps/note/templates/note/transactiontemplate_list.html:77
|
#: apps/note/templates/note/transactiontemplate_list.html:77
|
||||||
msgid "Unable to delete button "
|
msgid "Unable to delete button"
|
||||||
msgstr "Impossible de supprimer le bouton "
|
msgstr "Impossible de supprimer le bouton"
|
||||||
|
|
||||||
#: apps/note/templates/note/transactiontemplate_list.html:95
|
#: apps/note/templates/note/transactiontemplate_list.html:95
|
||||||
msgid "Button hidden"
|
msgid "Button hidden"
|
||||||
|
@ -1878,7 +1877,7 @@ msgid ""
|
||||||
"is expired."
|
"is expired."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Indique si la permission doit être attribuée même si l'adhésion de "
|
"Indique si la permission doit être attribuée même si l'adhésion de "
|
||||||
"l'utilisateur·ice est expirée."
|
"l'utilisateur⋅rice est expirée."
|
||||||
|
|
||||||
#: apps/permission/models.py:182
|
#: apps/permission/models.py:182
|
||||||
#: apps/permission/templates/permission/all_rights.html:89
|
#: apps/permission/templates/permission/all_rights.html:89
|
||||||
|
@ -1936,16 +1935,16 @@ msgstr ""
|
||||||
|
|
||||||
#: apps/permission/templates/permission/all_rights.html:12
|
#: apps/permission/templates/permission/all_rights.html:12
|
||||||
msgid "Users that have surnormal rights"
|
msgid "Users that have surnormal rights"
|
||||||
msgstr "Liste des utilisateur·ice·s ayant des droits surnormaux"
|
msgstr "Liste des utilisateur·rice·s ayant des droits surnormaux"
|
||||||
|
|
||||||
#: apps/permission/templates/permission/all_rights.html:16
|
#: apps/permission/templates/permission/all_rights.html:16
|
||||||
msgid "Superusers have all rights on everything, to manage the website."
|
msgid "Superusers have all rights on everything, to manage the website."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Les super-utilisateur·ice·s ont tous les droits sur tout, afin de gérer le site."
|
"Les super-utilisateur·rice·s ont tous les droits sur tout, afin de gérer le site."
|
||||||
|
|
||||||
#: apps/permission/templates/permission/all_rights.html:21
|
#: apps/permission/templates/permission/all_rights.html:21
|
||||||
msgid "Superusers"
|
msgid "Superusers"
|
||||||
msgstr "Super-utilisateur·ice·s"
|
msgstr "Super-utilisateur·rice·s"
|
||||||
|
|
||||||
#: apps/permission/templates/permission/all_rights.html:45
|
#: apps/permission/templates/permission/all_rights.html:45
|
||||||
msgid "Roles description"
|
msgid "Roles description"
|
||||||
|
@ -2026,7 +2025,7 @@ msgstr "inscription"
|
||||||
|
|
||||||
#: apps/registration/forms.py:40
|
#: apps/registration/forms.py:40
|
||||||
msgid "This email address is already used."
|
msgid "This email address is already used."
|
||||||
msgstr "Cet email est déjà pris."
|
msgstr "Cette adresse e-mail est déjà prise."
|
||||||
|
|
||||||
#: apps/registration/forms.py:60
|
#: apps/registration/forms.py:60
|
||||||
msgid "Register to the WEI"
|
msgid "Register to the WEI"
|
||||||
|
@ -2081,7 +2080,7 @@ msgstr "Activation du compte"
|
||||||
msgid ""
|
msgid ""
|
||||||
"An email has been sent. Please click on the link to activate your account."
|
"An email has been sent. Please click on the link to activate your account."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Un email vient de vous être envoyé. Merci de cliquer sur le lien de "
|
"Un e-mail vient de vous être envoyé. Merci de cliquer sur le lien de "
|
||||||
"validation pour activer votre compte."
|
"validation pour activer votre compte."
|
||||||
|
|
||||||
#: apps/registration/templates/registration/email_validation_email_sent.html:17
|
#: apps/registration/templates/registration/email_validation_email_sent.html:17
|
||||||
|
@ -2100,7 +2099,7 @@ msgstr "Valider le compte"
|
||||||
#: apps/registration/templates/registration/future_profile_detail.html:63
|
#: apps/registration/templates/registration/future_profile_detail.html:63
|
||||||
msgid ""
|
msgid ""
|
||||||
"The user declared that he/she opened a bank account in the Société générale."
|
"The user declared that he/she opened a bank account in the Société générale."
|
||||||
msgstr "L'utilisateur·ice a déclaré avoir ouvert un compte à la société générale."
|
msgstr "L'utilisateur·rice a déclaré avoir ouvert un compte à la société générale."
|
||||||
|
|
||||||
#: apps/registration/templates/registration/future_profile_detail.html:73
|
#: apps/registration/templates/registration/future_profile_detail.html:73
|
||||||
#: apps/wei/templates/wei/weimembership_form.html:127
|
#: apps/wei/templates/wei/weimembership_form.html:127
|
||||||
|
@ -2110,7 +2109,7 @@ msgstr "Valider l'inscription"
|
||||||
|
|
||||||
#: apps/registration/templates/registration/future_user_list.html:9
|
#: apps/registration/templates/registration/future_user_list.html:9
|
||||||
msgid "New user"
|
msgid "New user"
|
||||||
msgstr "Nouvel·le utilisateur·ice"
|
msgstr "Nouvel⋅le utilisateur⋅rice"
|
||||||
|
|
||||||
#: apps/registration/templates/registration/mails/email_validation_email.html:12
|
#: apps/registration/templates/registration/mails/email_validation_email.html:12
|
||||||
#: apps/registration/templates/registration/mails/email_validation_email.txt:3
|
#: apps/registration/templates/registration/mails/email_validation_email.txt:3
|
||||||
|
@ -2124,7 +2123,7 @@ msgid ""
|
||||||
"confirm your registration."
|
"confirm your registration."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Vous vous êtes inscrit·e récemment sur la Note Kfet. Merci de cliquer sur le "
|
"Vous vous êtes inscrit·e récemment sur la Note Kfet. Merci de cliquer sur le "
|
||||||
"lien ci-dessous pour confirmer votre adresse email."
|
"lien ci-dessous pour confirmer votre adresse e-mail."
|
||||||
|
|
||||||
#: apps/registration/templates/registration/mails/email_validation_email.html:26
|
#: apps/registration/templates/registration/mails/email_validation_email.html:26
|
||||||
#: apps/registration/templates/registration/mails/email_validation_email.txt:9
|
#: apps/registration/templates/registration/mails/email_validation_email.txt:9
|
||||||
|
@ -2154,11 +2153,11 @@ msgstr "L'équipe de la Note Kfet."
|
||||||
|
|
||||||
#: apps/registration/views.py:41
|
#: apps/registration/views.py:41
|
||||||
msgid "Register new user"
|
msgid "Register new user"
|
||||||
msgstr "Enregistrer un·e nouvel·le utilisateur·ice"
|
msgstr "Enregistrer un⋅e nouvel⋅le utilisateur⋅rice"
|
||||||
|
|
||||||
#: apps/registration/views.py:99
|
#: apps/registration/views.py:99
|
||||||
msgid "Email validation"
|
msgid "Email validation"
|
||||||
msgstr "Validation de l'adresse mail"
|
msgstr "Validation de l'adresse e-mail"
|
||||||
|
|
||||||
#: apps/registration/views.py:101
|
#: apps/registration/views.py:101
|
||||||
msgid "Validate email"
|
msgid "Validate email"
|
||||||
|
@ -2166,11 +2165,11 @@ msgstr "Valider l'adresse e-mail"
|
||||||
|
|
||||||
#: apps/registration/views.py:145
|
#: apps/registration/views.py:145
|
||||||
msgid "Email validation unsuccessful"
|
msgid "Email validation unsuccessful"
|
||||||
msgstr "La validation de l'adresse mail a échoué"
|
msgstr "La validation de l'adresse e-mail a échoué"
|
||||||
|
|
||||||
#: apps/registration/views.py:156
|
#: apps/registration/views.py:156
|
||||||
msgid "Email validation email sent"
|
msgid "Email validation email sent"
|
||||||
msgstr "L'email de vérification de l'adresse email a bien été envoyé"
|
msgstr "L'e-mail de vérification de l'adresse e-mail a bien été envoyé"
|
||||||
|
|
||||||
#: apps/registration/views.py:164
|
#: apps/registration/views.py:164
|
||||||
msgid "Resend email validation link"
|
msgid "Resend email validation link"
|
||||||
|
@ -2178,11 +2177,11 @@ msgstr "Renvoyer le lien de validation"
|
||||||
|
|
||||||
#: apps/registration/views.py:182
|
#: apps/registration/views.py:182
|
||||||
msgid "Pre-registered users list"
|
msgid "Pre-registered users list"
|
||||||
msgstr "Liste des utilisateur·ice·s en attente d'inscription"
|
msgstr "Liste des utilisateur⋅rices en attente d'inscription"
|
||||||
|
|
||||||
#: apps/registration/views.py:206
|
#: apps/registration/views.py:206
|
||||||
msgid "Unregistered users"
|
msgid "Unregistered users"
|
||||||
msgstr "Utilisateur·ice·s en attente d'inscription"
|
msgstr "Utilisateur·rices en attente d'inscription"
|
||||||
|
|
||||||
#: apps/registration/views.py:219
|
#: apps/registration/views.py:219
|
||||||
msgid "Registration detail"
|
msgid "Registration detail"
|
||||||
|
@ -2370,14 +2369,14 @@ msgstr "Crédits de la Société générale"
|
||||||
#: apps/treasury/models.py:315
|
#: apps/treasury/models.py:315
|
||||||
#, python-brace-format
|
#, python-brace-format
|
||||||
msgid "Soge credit for {user}"
|
msgid "Soge credit for {user}"
|
||||||
msgstr "Crédit de la société générale pour l'utilisateur·ice {user}"
|
msgstr "Crédit de la société générale pour l'utilisateur·rice {user}"
|
||||||
|
|
||||||
#: apps/treasury/models.py:445
|
#: apps/treasury/models.py:445
|
||||||
msgid ""
|
msgid ""
|
||||||
"This user doesn't have enough money to pay the memberships with its note. "
|
"This user doesn't have enough money to pay the memberships with its note. "
|
||||||
"Please ask her/him to credit the note before invalidating this credit."
|
"Please ask her/him to credit the note before invalidating this credit."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Cet·te utilisateur·ice n'a pas assez d'argent pour payer les adhésions avec sa "
|
"Cet·te utilisateur·rice n'a pas assez d'argent pour payer les adhésions avec sa "
|
||||||
"note. Merci de lui demander de recharger sa note avant d'invalider ce crédit."
|
"note. Merci de lui demander de recharger sa note avant d'invalider ce crédit."
|
||||||
|
|
||||||
#: apps/treasury/tables.py:20
|
#: apps/treasury/tables.py:20
|
||||||
|
@ -2430,7 +2429,7 @@ msgid ""
|
||||||
"implies regenerate it. Be careful if you manipulate old invoices."
|
"implies regenerate it. Be careful if you manipulate old invoices."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Attention : le template LaTeX est enregistré avec cet objet. Modifier la "
|
"Attention : le template LaTeX est enregistré avec cet objet. Modifier la "
|
||||||
"facture implique la regénérer. Faites attention si vous manipulez de "
|
"facture implique la régénérer. Faites attention si vous manipulez de "
|
||||||
"vieilles factures."
|
"vieilles factures."
|
||||||
|
|
||||||
#: apps/treasury/templates/treasury/invoice_form.html:69
|
#: apps/treasury/templates/treasury/invoice_form.html:69
|
||||||
|
@ -2529,7 +2528,7 @@ msgid ""
|
||||||
"If this credit is validated, then the user won't be able to ask for a credit "
|
"If this credit is validated, then the user won't be able to ask for a credit "
|
||||||
"from the Société générale."
|
"from the Société générale."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Si ce crédit est validé, alors l'utilisateur·ice ne pourra plus demander d'être "
|
"Si ce crédit est validé, alors l'utilisateur·rice ne pourra plus demander d'être "
|
||||||
"crédité·e par la Société générale à l'avenir."
|
"crédité·e par la Société générale à l'avenir."
|
||||||
|
|
||||||
#: apps/treasury/templates/treasury/sogecredit_detail.html:44
|
#: apps/treasury/templates/treasury/sogecredit_detail.html:44
|
||||||
|
@ -2545,13 +2544,13 @@ msgid ""
|
||||||
"Warning: if you don't validate this credit, the note of the user doesn't "
|
"Warning: if you don't validate this credit, the note of the user doesn't "
|
||||||
"have enough money to pay its memberships."
|
"have enough money to pay its memberships."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Attention : si vous ne validez pas ce crédit, la note de l'utilisateur·ice n'a "
|
"Attention : si vous ne validez pas ce crédit, la note de l'utilisateur·rice n'a "
|
||||||
"pas assez d'argent pour payer les adhésions."
|
"pas assez d'argent pour payer les adhésions."
|
||||||
|
|
||||||
#: apps/treasury/templates/treasury/sogecredit_detail.html:56
|
#: apps/treasury/templates/treasury/sogecredit_detail.html:56
|
||||||
msgid "Please ask the user to credit its note before deleting this credit."
|
msgid "Please ask the user to credit its note before deleting this credit."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Merci de demander à l'utilisateur·ice de recharger sa note avant de supprimer la "
|
"Merci de demander à l'utilisateur·rice de recharger sa note avant de supprimer la "
|
||||||
"demande de crédit."
|
"demande de crédit."
|
||||||
|
|
||||||
#: apps/treasury/templates/treasury/sogecredit_detail.html:63
|
#: apps/treasury/templates/treasury/sogecredit_detail.html:63
|
||||||
|
@ -2570,7 +2569,7 @@ msgstr "Filtrer avec uniquement les crédits non valides"
|
||||||
#: apps/treasury/templates/treasury/sogecredit_list.html:50
|
#: apps/treasury/templates/treasury/sogecredit_list.html:50
|
||||||
msgid "There is no matched user that have asked for a Société générale credit."
|
msgid "There is no matched user that have asked for a Société générale credit."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Il n'y a pas d'utilisateur·ice trouvé·e ayant demandé un crédit de la Société "
|
"Il n'y a pas d'utilisateur·rice trouvé·e ayant demandé un crédit de la Société "
|
||||||
"générale."
|
"générale."
|
||||||
|
|
||||||
#: apps/treasury/templates/treasury/sogecredit_list.html:63
|
#: apps/treasury/templates/treasury/sogecredit_list.html:63
|
||||||
|
@ -2631,7 +2630,7 @@ msgstr "WEI"
|
||||||
#: apps/wei/forms/registration.py:35
|
#: apps/wei/forms/registration.py:35
|
||||||
msgid "The selected user is not validated. Please validate its account first"
|
msgid "The selected user is not validated. Please validate its account first"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"L'utilisateur·ice sélectionné·e n'est pas validé·e. Merci de d'abord valider son "
|
"L'utilisateur·rice sélectionné·e n'est pas validé·e. Merci de d'abord valider son "
|
||||||
"compte"
|
"compte"
|
||||||
|
|
||||||
#: apps/wei/forms/registration.py:59 apps/wei/models.py:126
|
#: apps/wei/forms/registration.py:59 apps/wei/models.py:126
|
||||||
|
@ -2644,7 +2643,7 @@ msgid ""
|
||||||
"This choice is not definitive. The WEI organizers are free to attribute for "
|
"This choice is not definitive. The WEI organizers are free to attribute for "
|
||||||
"you a bus and a team, in particular if you are a free eletron."
|
"you a bus and a team, in particular if you are a free eletron."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Ce choix n'est pas définitif. Les organisateur·ice·s du WEI sont libres de vous "
|
"Ce choix n'est pas définitif. Les organisateur·rice·s du WEI sont libres de vous "
|
||||||
"attribuer un bus et une équipe, en particulier si vous êtes un·e électron "
|
"attribuer un bus et une équipe, en particulier si vous êtes un·e électron "
|
||||||
"libre."
|
"libre."
|
||||||
|
|
||||||
|
@ -2797,7 +2796,7 @@ msgstr "première année"
|
||||||
|
|
||||||
#: apps/wei/models.py:249
|
#: apps/wei/models.py:249
|
||||||
msgid "Tells if the user is new in the school."
|
msgid "Tells if the user is new in the school."
|
||||||
msgstr "Indique si l'utilisateur·ice est nouveau dans l'école."
|
msgstr "Indique si l'utilisateur⋅rice est nouvelleeau dans l'école."
|
||||||
|
|
||||||
#: apps/wei/models.py:254
|
#: apps/wei/models.py:254
|
||||||
msgid "registration information"
|
msgid "registration information"
|
||||||
|
@ -2837,19 +2836,19 @@ msgstr "Adhésions au WEI"
|
||||||
|
|
||||||
#: apps/wei/tables.py:105
|
#: apps/wei/tables.py:105
|
||||||
msgid "The user does not have enough money."
|
msgid "The user does not have enough money."
|
||||||
msgstr "L'utilisateur·ice n'a pas assez d'argent."
|
msgstr "L'utilisateur⋅rice n'a pas assez d'argent."
|
||||||
|
|
||||||
#: apps/wei/tables.py:108
|
#: apps/wei/tables.py:108
|
||||||
msgid ""
|
msgid ""
|
||||||
"The user is in first year. You may validate the credit, the algorithm will "
|
"The user is in first year. You may validate the credit, the algorithm will "
|
||||||
"run later."
|
"run later."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"L'utilisateur·ice est en première année, vous pouvez valider le crédit, "
|
"L'utilisateur·rice est en première année, vous pouvez valider le crédit, "
|
||||||
"l'algorithme tournera plus tard."
|
"l'algorithme tournera plus tard."
|
||||||
|
|
||||||
#: apps/wei/tables.py:111
|
#: apps/wei/tables.py:111
|
||||||
msgid "The user has enough money, you can validate the registration."
|
msgid "The user has enough money, you can validate the registration."
|
||||||
msgstr "L'utilisateur·ice a assez d'argent, l'inscription est possible."
|
msgstr "L'utilisateur⋅rice a assez d'argent, l'inscription est possible."
|
||||||
|
|
||||||
#: apps/wei/tables.py:143
|
#: apps/wei/tables.py:143
|
||||||
msgid "Year"
|
msgid "Year"
|
||||||
|
@ -2870,19 +2869,19 @@ msgstr "Nombre de membres"
|
||||||
|
|
||||||
#: apps/wei/tables.py:226 apps/wei/tables.py:257
|
#: apps/wei/tables.py:226 apps/wei/tables.py:257
|
||||||
msgid "members"
|
msgid "members"
|
||||||
msgstr "adhérent·e·s"
|
msgstr "adhérent·es"
|
||||||
|
|
||||||
#: apps/wei/tables.py:287
|
#: apps/wei/tables.py:287
|
||||||
msgid "suggested first year"
|
msgid "suggested first year"
|
||||||
msgstr "1A suggéré·e·s"
|
msgstr "1A suggéré·es"
|
||||||
|
|
||||||
#: apps/wei/tables.py:293
|
#: apps/wei/tables.py:293
|
||||||
msgid "validated first year"
|
msgid "validated first year"
|
||||||
msgstr "1A validé·e·s"
|
msgstr "1A validé·es"
|
||||||
|
|
||||||
#: apps/wei/tables.py:299
|
#: apps/wei/tables.py:299
|
||||||
msgid "validated staff"
|
msgid "validated staff"
|
||||||
msgstr "2A+ validé·e·s"
|
msgstr "2A+ validé·es"
|
||||||
|
|
||||||
#: apps/wei/tables.py:310
|
#: apps/wei/tables.py:310
|
||||||
msgid "free seats"
|
msgid "free seats"
|
||||||
|
@ -2922,7 +2921,7 @@ msgstr "L'adhésion au BDE est offerte avec l'inscription au WEI."
|
||||||
|
|
||||||
#: apps/wei/templates/wei/base.html:51
|
#: apps/wei/templates/wei/base.html:51
|
||||||
msgid "WEI fee (unpaid students)"
|
msgid "WEI fee (unpaid students)"
|
||||||
msgstr "Prix du WEI (étudiants)"
|
msgstr "Prix du WEI (étudiant⋅es)"
|
||||||
|
|
||||||
#: apps/wei/templates/wei/base.html:76
|
#: apps/wei/templates/wei/base.html:76
|
||||||
msgid "WEI list"
|
msgid "WEI list"
|
||||||
|
@ -2930,11 +2929,11 @@ msgstr "Liste des WEI"
|
||||||
|
|
||||||
#: apps/wei/templates/wei/base.html:81 apps/wei/views.py:528
|
#: apps/wei/templates/wei/base.html:81 apps/wei/views.py:528
|
||||||
msgid "Register 1A"
|
msgid "Register 1A"
|
||||||
msgstr "Inscrire un 1A"
|
msgstr "Inscrire un⋅e 1A"
|
||||||
|
|
||||||
#: apps/wei/templates/wei/base.html:85 apps/wei/views.py:614
|
#: apps/wei/templates/wei/base.html:85 apps/wei/views.py:614
|
||||||
msgid "Register 2A+"
|
msgid "Register 2A+"
|
||||||
msgstr "Inscrire un 2A+"
|
msgstr "Inscrire un⋅e 2A+"
|
||||||
|
|
||||||
#: apps/wei/templates/wei/base.html:93
|
#: apps/wei/templates/wei/base.html:93
|
||||||
msgid "Add bus"
|
msgid "Add bus"
|
||||||
|
@ -3062,7 +3061,7 @@ msgstr "L'inscription a déjà été validée et ne peut pas être dévalidée."
|
||||||
|
|
||||||
#: apps/wei/templates/wei/weimembership_form.html:132
|
#: apps/wei/templates/wei/weimembership_form.html:132
|
||||||
msgid "The user joined the bus"
|
msgid "The user joined the bus"
|
||||||
msgstr "L'utilisateur·ice a rejoint le bus"
|
msgstr "L'utilisateur⋅rice a rejoint le bus"
|
||||||
|
|
||||||
#: apps/wei/templates/wei/weimembership_form.html:133
|
#: apps/wei/templates/wei/weimembership_form.html:133
|
||||||
msgid "in the team"
|
msgid "in the team"
|
||||||
|
@ -3107,7 +3106,7 @@ msgstr ""
|
||||||
|
|
||||||
#: apps/wei/templates/wei/weimembership_form.html:166
|
#: apps/wei/templates/wei/weimembership_form.html:166
|
||||||
msgid "The user didn't give her/his caution check."
|
msgid "The user didn't give her/his caution check."
|
||||||
msgstr "L'utilisateur·ice n'a pas donné son chèque de caution."
|
msgstr "L'utilisateur⋅rice n'a pas donné son chèque de caution."
|
||||||
|
|
||||||
#: apps/wei/templates/wei/weimembership_form.html:174
|
#: apps/wei/templates/wei/weimembership_form.html:174
|
||||||
msgid ""
|
msgid ""
|
||||||
|
@ -3115,13 +3114,13 @@ msgid ""
|
||||||
"membership will be processed automatically, the WEI registration includes "
|
"membership will be processed automatically, the WEI registration includes "
|
||||||
"the membership fee."
|
"the membership fee."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Cet·te utilisateur·ice n'est pas membre du club Kfet pour l'année à venir. "
|
"Cet⋅te utilisateur⋅rice n'est pas membre du club Kfet pour l'année à venir. "
|
||||||
"L'adhésion va être faite automatiquement, l'inscription au WEI inclut le "
|
"L'adhésion va être faite automatiquement, l'inscription au WEI inclut le "
|
||||||
"coût d'adhésion."
|
"coût d'adhésion."
|
||||||
|
|
||||||
#: apps/wei/templates/wei/weimembership_list.html:27
|
#: apps/wei/templates/wei/weimembership_list.html:27
|
||||||
msgid "View unvalidated registrations..."
|
msgid "View unvalidated registrations…"
|
||||||
msgstr "Voir les inscriptions non validées ..."
|
msgstr "Voir les inscriptions non validées…"
|
||||||
|
|
||||||
#: apps/wei/templates/wei/weiregistration_confirm_delete.html:16
|
#: apps/wei/templates/wei/weiregistration_confirm_delete.html:16
|
||||||
msgid "This registration is already validated and can't be deleted."
|
msgid "This registration is already validated and can't be deleted."
|
||||||
|
@ -3141,8 +3140,8 @@ msgid "There is no pre-registration found with this pattern."
|
||||||
msgstr "Il n'y a pas de pré-inscription en attente avec cette entrée."
|
msgstr "Il n'y a pas de pré-inscription en attente avec cette entrée."
|
||||||
|
|
||||||
#: apps/wei/templates/wei/weiregistration_list.html:27
|
#: apps/wei/templates/wei/weiregistration_list.html:27
|
||||||
msgid "View validated memberships..."
|
msgid "View validated memberships…"
|
||||||
msgstr "Voir les adhésions validées ..."
|
msgstr "Voir les adhésions validées…"
|
||||||
|
|
||||||
#: apps/wei/views.py:58
|
#: apps/wei/views.py:58
|
||||||
msgid "Search WEI"
|
msgid "Search WEI"
|
||||||
|
@ -3198,7 +3197,7 @@ msgstr "Gérer l'équipe WEI"
|
||||||
|
|
||||||
#: apps/wei/views.py:492
|
#: apps/wei/views.py:492
|
||||||
msgid "Register first year student to the WEI"
|
msgid "Register first year student to the WEI"
|
||||||
msgstr "Inscrire un 1A au WEI"
|
msgstr "Inscrire un⋅e 1A au WEI"
|
||||||
|
|
||||||
#: apps/wei/views.py:550 apps/wei/views.py:649
|
#: apps/wei/views.py:550 apps/wei/views.py:649
|
||||||
msgid "This user is already registered to this WEI."
|
msgid "This user is already registered to this WEI."
|
||||||
|
@ -3209,12 +3208,12 @@ msgid ""
|
||||||
"This user can't be in her/his first year since he/she has already "
|
"This user can't be in her/his first year since he/she has already "
|
||||||
"participated to a WEI."
|
"participated to a WEI."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Cet·te utilisateur·ice ne peut pas être en première année puisqu'iel a déjà "
|
"Cet⋅te utilisateur⋅rice ne peut pas être en première année puisqu'iel a déjà "
|
||||||
"participé à un WEI."
|
"participé à un WEI."
|
||||||
|
|
||||||
#: apps/wei/views.py:578
|
#: apps/wei/views.py:578
|
||||||
msgid "Register old student to the WEI"
|
msgid "Register old student to the WEI"
|
||||||
msgstr "Inscrire un 2A+ au WEI"
|
msgstr "Inscrire un⋅e 2A+ au WEI"
|
||||||
|
|
||||||
#: apps/wei/views.py:633 apps/wei/views.py:721
|
#: apps/wei/views.py:633 apps/wei/views.py:721
|
||||||
msgid "You already opened an account in the Société générale."
|
msgid "You already opened an account in the Société générale."
|
||||||
|
@ -3308,10 +3307,10 @@ msgid ""
|
||||||
"sent to webmasters with the detail of the error, and this will be fixed "
|
"sent to webmasters with the detail of the error, and this will be fixed "
|
||||||
"soon. You can now drink a beer."
|
"soon. You can now drink a beer."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Désolé, une erreur est survenue lors de l'analyse de votre requête. Un email "
|
"Désolé, une erreur est survenue lors de l'analyse de votre requête. Un e-mail "
|
||||||
"a été envoyé aux responsables de la plateforme avec les détails de cette "
|
"a été envoyé aux responsables de la plateforme avec les détails de cette "
|
||||||
"erreur, qui sera corrigée rapidement. Vous pouvez désormais aller boire une "
|
"erreur, qui sera corrigée rapidement. Vous pouvez désormais aller boire une "
|
||||||
"bière."
|
"bière, avec modération."
|
||||||
|
|
||||||
#: note_kfet/templates/autocomplete_model.html:15
|
#: note_kfet/templates/autocomplete_model.html:15
|
||||||
msgid "Reset"
|
msgid "Reset"
|
||||||
|
@ -3323,7 +3322,7 @@ msgstr "La note du BDE de l'ENS Paris-Saclay."
|
||||||
|
|
||||||
#: note_kfet/templates/base.html:78
|
#: note_kfet/templates/base.html:78
|
||||||
msgid "Users"
|
msgid "Users"
|
||||||
msgstr "Utilisateur·ice·s"
|
msgstr "Utilisateur·rices"
|
||||||
|
|
||||||
#: note_kfet/templates/base.html:84
|
#: note_kfet/templates/base.html:84
|
||||||
msgid "Clubs"
|
msgid "Clubs"
|
||||||
|
@ -3404,7 +3403,7 @@ msgstr "Charte Info (FR)"
|
||||||
|
|
||||||
#: note_kfet/templates/base_search.html:15
|
#: note_kfet/templates/base_search.html:15
|
||||||
msgid "Search by attribute such as name…"
|
msgid "Search by attribute such as name…"
|
||||||
msgstr "Chercher par un attribut tel que le nom …"
|
msgstr "Chercher par un attribut tel que le nom…"
|
||||||
|
|
||||||
#: note_kfet/templates/base_search.html:23
|
#: note_kfet/templates/base_search.html:23
|
||||||
msgid "There is no results."
|
msgid "There is no results."
|
||||||
|
@ -3602,7 +3601,7 @@ msgid ""
|
||||||
"If you don't receive an email, please make sure you've entered the address "
|
"If you don't receive an email, please make sure you've entered the address "
|
||||||
"you registered with, and check your spam folder."
|
"you registered with, and check your spam folder."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Si vous ne recevez pas d'email, vérifiez que vous avez bien utilisé "
|
"Si vous ne recevez pas d'e-mail, vérifiez que vous avez bien utilisé "
|
||||||
"l'adresse associée à votre compte, et regarder également le dossier spam."
|
"l'adresse associée à votre compte, et regarder également le dossier spam."
|
||||||
|
|
||||||
#: note_kfet/templates/registration/password_reset_form.html:13
|
#: note_kfet/templates/registration/password_reset_form.html:13
|
||||||
|
@ -3624,7 +3623,7 @@ msgid ""
|
||||||
"Kfet and pay the registration fee. You must also validate your email address "
|
"Kfet and pay the registration fee. You must also validate your email address "
|
||||||
"by following the link you received."
|
"by following the link you received."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Si vous vous êtes déjà inscrit·e·s, votre inscription a bien été prise en "
|
"Si vous vous êtes déjà inscrit·e, votre inscription a bien été prise en "
|
||||||
"compte. Le BDE doit d'abord valider votre compte avant que vous puissiez "
|
"compte. Le BDE doit d'abord valider votre compte avant que vous puissiez "
|
||||||
"vous connecter. Vous devez vous rendre à la Kfet et payer les frais "
|
"vous connecter. Vous devez vous rendre à la Kfet et payer les frais "
|
||||||
"d'adhésion. Vous devez également valider votre adresse email en suivant le "
|
"d'adhésion. Vous devez également valider votre adresse email en suivant le "
|
||||||
|
|
Loading…
Reference in New Issue