From acda0e9fe11a1512fda7495f0f96711fd2a3d9cd Mon Sep 17 00:00:00 2001 From: Alexandre Iooss Date: Wed, 22 Sep 2021 21:32:32 +0200 Subject: [PATCH] Add README.md --- README.md | 87 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 87 insertions(+) create mode 100644 README.md diff --git a/README.md b/README.md new file mode 100644 index 0000000..9b2e920 --- /dev/null +++ b/README.md @@ -0,0 +1,87 @@ +# Serveur photos 2021 + +[![License: GPL v3](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0.txt) + +## Table des matières + + - [Installation d'une instance de développement](#installation-dune-instance-de-développement) + - [Installation d'une instance de production](#installation-dune-instance-de-production) + +## Installation d'une instance de développement + +L'instance de développement installe la majorité des dépendances dans un environnement Python isolé. +Bien que cela permette de créer une instance sur toutes les distributions, +**cela veut dire que vos dépendances ne seront pas mises à jour automatiquement.** + +1. **Installation des dépendances de la distribution.** + Il y a quelques dépendances qui ne sont pas trouvable dans PyPI. + On donne ci-dessous l'exemple pour une distribution basée sur Debian, mais vous pouvez facilement adapter pour ArchLinux ou autre. + + ```bash + $ sudo apt update + $ sudo apt install --no-install-recommends -y \ + ipython3 python3-setuptools python3-venv python3-dev \ + gettext git + ``` + +2. **Clonage du dépot** là où vous voulez : + + ```bash + $ git clone git@gitlab.crans.org:bde/photo21.git && cd photo21 + ``` + +3. **Création d'un environment de travail Python décorrélé du système.** + On n'utilise pas `--system-site-packages` ici pour ne pas avoir des clashs de versions de modules avec le système. + + ```bash + $ python3 -m venv env + $ source env/bin/activate # entrer dans l'environnement + (env)$ pip3 install -r requirements.txt + (env)$ deactivate # sortir de l'environnement + ``` + +4. **Migrations et chargement des données initiales.** + Pour initialiser la base de données avec de quoi travailler. + + ```bash + (env)$ ./manage.py collectstatic --noinput + (env)$ ./manage.py compilemessages + (env)$ ./manage.py migrate + (env)$ ./manage.py loaddata initial + (env)$ ./manage.py createsuperuser # Création d'un utilisateur initial + ``` + +6. Enjoy : + + ```bash + (env)$ ./manage.py runserver 0.0.0.0:8000 + ``` + +En mettant `0.0.0.0:8000` après `runserver`, vous rendez votre instance Django +accessible depuis l'ensemble de votre réseau, pratique pour tester le rendu +de la note sur un téléphone ! + +## Installation d'une instance de production +TODO + +## Documentation + +La documentation des classes et fonctions est directement dans le code et est explorable à partir de la partie documentation de l'interface d'administration de Django. +**Commentez votre code !** + +## FAQ + +### Regénérer les fichiers de traduction + +Pour regénérer les traductions vous pouvez vous placer à la racine du projet et lancer le script `makemessages`. +Il faut penser à ignorer les dossiers ne contenant pas notre code, dont le virtualenv. + +```bash +python3 manage.py makemessages -i env +``` + +Une fois les fichiers édités, vous pouvez compiler les nouvelles traductions avec + +```bash +python3 manage.py compilemessages +```