Transition d’années
Entre deux sessions du TFJM², certaines opérations doivent être effectuées chaque année, afin de réinitialiser les données et de passer à l’année suivante.
Réinitialisation de la base de données
Conservation des autorisations de droit à l’image
La base de données du TFJM² est supprimée chaque année, avant chaque tournoi. Il n’y a pas de conservation de données personnelles à l’exception des autorisations de droit à l’image qui doivent être conservées pour des raisons légales pendant 5 ans.
Elles doivent alors être stockées sur Owncloud. Pour cela, il faut commencer par créer un dossier dans Owncloud, qui stockera lesdites autorisations.
Rendez-vous ensuite dans le conteneur Docker et exécuter le script :
./manage.py export_photo_authorizations
Cela a pour effet de générer un dossier dans output/photo_authorizations
, qui contient
un dossier par équipe avec les différentes autorisations de droit à l’image.
Il faut maintenant récupérer ce dossier. Sortir du conteneur, et exécuter dans /srv/TFJM
:
sudo docker cp tfjm-inscription-1:/code/output/photo_authorizations .
sudo mv photo_authorizations/* "data/owncloud/data/Emmy/files/Autorisations de droit à l'image/Autorisations de droit à l'image 2024/"
sudo chown -R www-data:root "data/owncloud/data/Emmy/files/Autorisations de droit à l'image/Autorisations de droit à l'image 2024"
sudo rmdir photo_authorizations
Il faut enfin réactualiser Owncloud. Exécuter en tant que www-data :
sudo docker compose exec -u www-data cloud php occ files:scan Emmy
Vérifiez enfin que les fichiers sont bien accessibles dans l’interface Web. Ne pas oublier enfin de partager le dossier.
Sauvegarde de secours
Si les données doivent être supprimées, il peut être utile de réaliser une sauvegarde à conserver quelques mois.
Danger
Cette sauvegarde ne doit être faite qu’à des fins utiles et supprimée dès que plus nécessaire.
Sauvegardez alors le dossier /srv/TFJM/data/inscription/media
et exportez la base de données :
sudo cp -r data/inscription/media data/inscription/media-2024
sudo docker compose exec -u postgres postgres pg_dump inscription_tfjm | sudo tee inscription_tfjm_bkp_2024.sql > /dev/null
Réinitialisation effective
Il est désormais possible de réinitialiser la base de données, après avoir éteint le serveur :
sudo docker compose stop inscription
sudo rm -r data/inscription/media/*
sudo docker compose exec -u postgres postgres dropdb inscription_tfjm
sudo docker compose exec -u postgres postgres createdb -O inscription_tfjm inscription_tfjm
Redémarrez enfin le serveur (les migrations seront créées automatiquement) et créez un nouveau compte administrateur⋅rice :
sudo docker compose up -d inscription
sudo docker compose exec inscription bash
./manage.py createsuperuser
Vérifiez finalement le bon fonctionnement du site.
Sites Django
Après avoir réinitialisé les données, il faut mettre à jour le site Django, qui permettra d’avoir notamment des noms de domaine correct dans les mails envoyés.
Se connecter alors sur le site réouvert, puis dans la partie « Administration », chercher la section « Sites » et modifier l’unique site présent. Vous pouvez ensuite effectuer les modifications à réaliser.
Nouveaux paramètres pour la nouvelle année
Certains paramètres doivent être modifiés pour prendre en compte la nouvelle année.
Dates d’inscription
Les inscriptions sont permises uniquement entre l’ouverture et la fermeture, afin d’éviter d’avoir des personnes s’inscrivant en dehors du TFJM².
Pour cela, dans votre projet local, rendez-vous dans tfjm/settings.py
et cherchez
le paramètre REGISTRATION_DATES
(pour le TFJM²). Modifiez alors les sous-paramètres
open
et close
pour définir les dates pendant lesquelles les inscriptions des
participant⋅es sont permises pour cette nouvelle année. Elles doivent être au format ISO.
Exemple pour l’année 2025 où les inscriptions ouvrent au 8 janvier midi pour fermer le 2 mars à 22h :
REGISTRATION_DATES = dict(
open=datetime.fromisoformat("2025-01-15T12:00:00+0100"),
close=datetime.fromisoformat("2025-03-02T22:00:00+0100"),
)
Il faudra ensuite commiter la modification et redémarrer le serveur pour que la modification prenne effet.
Noms des problèmes
Toujours dans la configuration dans tfjm/settings.py
, la liste des problèmes doit être
modifiée pour que leurs noms s’affichent correctement lors du tirage au sort.
Cherchez le paramètre PROBLEMS
et mettez alors à jour la liste, dans l’ordre, des noms
des problèmes.
À nouveau, il est nécessaire de commiter la modification et redémarrer le serveur.
Paramètres des tournois
Il faut enfin paramétrer les différentes dates des tournois.
Pour cela, connectez-vous sur la plateforme (avec un compte administrateur⋅rice), et dans l’onglet « Tournois », vous pouvez créer les différents tournois avec les différentes dates pour chaque tournoi. Plus d’information sur les différents paramètres dans la section concernée
À la fin du tournoi
Lorsque le tournoi est terminé, il faut récupérer les informations à stocker de façon pérenne, notamment les solutions des équipes, les résultats ainsi que les autorisation de droit à l’image comme indiqué précédemment.
Conservation des autorisations de droit à l’image
Se référer à la section plus haut.
Conservation des solutions des équipes
Le processus est très similaire à la conservation des autorisations de droit à l’image.
Il faut d’abord, dans le conteneur, lancer le script dédié pour récupérer les solutions
dans /code/output/solutions
:
./manage.py export_solutions
On sort du conteneur et on récupère les solutions pour les déplacer dans Owncloud :
sudo docker cp tfjm-inscription-1:/code/output/solutions .
sudo mv solutions/* "data/owncloud/data/Emmy/files/Solutions écrites 2024/"
sudo chown -R www-data:root "data/owncloud/data/Emmy/files/Solutions écrites 2024"
sudo rmdir solutions
Il faut enfin réactualiser Owncloud. Exécuter en tant que www-data :
sudo docker compose exec -u www-data cloud php occ files:scan Emmy
Vérifiez enfin que les fichiers sont bien accessibles dans l’interface Web. Ne pas oublier enfin de partager le dossier.
Génération de la page de résultats Wordpress
Pour finir, il est possible de récupérer les notes pour chaque tournoi afin de générer la page Wordpress dans la section Éditions précédentes.
Il suffit de lancer le script ./manage.py export_results
, qui donne le texte brut pour
Wordpress à ajouter sur la page de l’édition qui vient de se terminer dans l’onglet
Éditions précédentes.
Pensez à bien inclure sur cette page le lien vers les problèmes de l’année, ainsi que le lien vers le dossier partagé dans le Owncloud concernant les solutions des équipes.
Assurez-vous de mettre à jour la page Éditions précédentes afin d’inclure le lien vers la page nouvellement créée.