1
0
mirror of https://gitlab.crans.org/bde/nk20 synced 2024-11-30 04:13:01 +00:00
nk20/README.md

233 lines
7.8 KiB
Markdown
Raw Normal View History

2019-07-07 21:31:20 +00:00
# NoteKfet 2020
2019-07-08 10:59:27 +00:00
[![License: GPL v3](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0.txt)
2020-08-10 16:27:45 +00:00
[![pipeline status](https://gitlab.crans.org/bde/nk20/badges/master/pipeline.svg)](https://gitlab.crans.org/bde/nk20/commits/master)
2019-07-08 10:59:27 +00:00
[![coverage report](https://gitlab.crans.org/bde/nk20/badges/master/coverage.svg)](https://gitlab.crans.org/bde/nk20/commits/master)
2019-07-07 21:31:20 +00:00
## Installation sur un serveur
2020-08-10 16:26:45 +00:00
On supposera pour la suite que vous utilisez une installation de Debian Buster ou Ubuntu 20.04 fraîche ou bien configuré.
2019-07-07 21:31:20 +00:00
2020-08-10 16:26:45 +00:00
Pour aller vite vous pouvez lancer le Playbook Ansible fournit dans ce dépôt en l'adaptant.
Sinon vous pouvez suivre les étapes ici.
2019-07-07 21:31:20 +00:00
2020-08-10 16:26:45 +00:00
### Installation avec Debian/Ubuntu
2019-07-07 21:31:20 +00:00
2020-08-10 16:26:45 +00:00
1. **Installation des dépendances APT.**
2020-08-10 16:26:45 +00:00
```bash
$ sudo apt install nginx python3 python3-pip python3-dev uwsgi uwsgi-plugin-python3 python3-venv git acl
```
2020-08-10 16:26:45 +00:00
La génération des factures de l'application trésorerie nécessite une installation de LaTeX suffisante,
2019-07-07 21:31:20 +00:00
2020-08-10 16:26:45 +00:00
```bash
$ sudo apt install texlive-latex-extra texlive-fonts-extra texlive-lang-french
```
2019-07-07 21:31:20 +00:00
2020-08-10 16:26:45 +00:00
2. **Clonage du dépot** dans `/var/www/note_kfet`,
2019-08-15 15:59:56 +00:00
2020-08-10 16:26:45 +00:00
```bash
$ mkdir -p /var/www/note_kfet && cd /var/www/note_kfet
$ sudo chown www-data:www-data .
$ sudo chmod g+rwx .
$ sudo -u www-data git clone git@gitlab.crans.org:bde/nk20.git .
```
2019-07-07 21:31:20 +00:00
2020-08-10 16:26:45 +00:00
3. **Création d'un environment de travail Python décorrélé du système.**
2019-07-07 21:31:20 +00:00
2020-08-10 16:26:45 +00:00
```bash
$ python3 -m venv env
$ source env/bin/activate
(env)$ pip3 install -r requirements/base.txt
(env)$ pip3 install -r requirements/prod.txt # uniquement en prod, nécessite une base postgres
(env)$ deactivate # sortir de l'environnement
```
2019-07-07 21:31:20 +00:00
2020-08-10 16:26:45 +00:00
4. **Pour configurer UWSGI et NGINX**, des exemples de conf sont disponibles.
**_Modifier le fichier pour être en accord avec le reste de votre config_**
2020-02-02 12:41:43 +00:00
2020-08-10 16:26:45 +00:00
```bash
$ cp nginx_note.conf_example nginx_note.conf
$ sudo ln -sf /var/www/note_kfet/nginx_note.conf /etc/nginx/sites-enabled/
```
2020-02-02 12:41:43 +00:00
2020-08-10 16:26:45 +00:00
Si l'on a un emperor (plusieurs instance uwsgi):
2020-02-02 12:41:43 +00:00
2020-08-10 16:26:45 +00:00
```bash
$ sudo ln -sf /var/www/note_kfet/uwsgi_note.ini /etc/uwsgi/sites/
```
2019-07-07 21:31:20 +00:00
2020-08-10 16:26:45 +00:00
Sinon si on est dans le cas habituel :
2019-08-15 15:59:56 +00:00
2020-08-10 16:26:45 +00:00
```bash
$ sudo ln -sf /var/www/note_kfet/uwsgi_note.ini /etc/uwsgi/apps-enabled/
```
2020-02-02 12:41:43 +00:00
Le touch-reload est activé par défault, pour redémarrer la note il suffit donc de faire `touch uwsgi_note.ini`.
2020-08-10 16:26:45 +00:00
5. **Base de données.** En production on utilise PostgreSQL.
2019-07-07 21:31:20 +00:00
2020-01-27 21:36:59 +00:00
$ sudo apt-get install postgresql postgresql-contrib libpq-dev
(env)$ pip3 install psycopg2
2020-08-10 16:26:45 +00:00
2020-01-27 21:36:59 +00:00
La config de la base de donnée se fait comme suit:
2020-08-10 16:26:45 +00:00
2020-01-27 21:36:59 +00:00
a. On se connecte au shell de psql
2020-08-10 16:26:45 +00:00
2020-01-27 21:36:59 +00:00
$ sudo su - postgres
$ psql
2020-08-10 16:26:45 +00:00
2020-01-27 21:36:59 +00:00
b. On sécurise l'utilisateur postgres
2020-08-10 16:26:45 +00:00
2020-01-27 21:36:59 +00:00
postgres=# \password
Enter new password:
2020-08-10 16:26:45 +00:00
2020-01-27 21:36:59 +00:00
Conservez ce mot de passe de la meme manière que tous les autres.
2020-08-10 16:26:45 +00:00
2020-01-27 21:36:59 +00:00
c. On créer la basse de donnée, et l'utilisateur associé
2020-08-10 16:26:45 +00:00
2020-01-27 21:36:59 +00:00
postgres=# CREATE USER note WITH PASSWORD 'un_mot_de_passe_sur';
CREATE ROLE
postgres=# CREATE DATABASE note_db OWNER note;
CREATE DATABASE
2020-03-11 14:54:12 +00:00
Si tout va bien :
2020-08-10 16:26:45 +00:00
2020-01-27 21:36:59 +00:00
postgres=#\list
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
-----------+----------+----------+-------------+-------------+-----------------------
note_db | note | UTF8 | fr_FR.UTF-8 | fr_FR.UTF-8 |
postgres | postgres | UTF8 | fr_FR.UTF-8 | fr_FR.UTF-8 |
template0 | postgres | UTF8 | fr_FR.UTF-8 | fr_FR.UTF-8 | =c/postgres+postgres=CTc/postgres
template1 | postgres | UTF8 | fr_FR.UTF-8 | fr_FR.UTF-8 | =c/postgres +postgres=CTc/postgres
(4 rows)
2020-08-10 16:26:45 +00:00
6. Variable d'environnement et Migrations
2020-03-11 14:54:12 +00:00
On copie le fichier `.env_example` vers le fichier `.env` à la racine du projet
et on renseigne des secrets et des paramètres :
2020-08-10 16:26:45 +00:00
DJANGO_APP_STAGE=dev # ou "prod"
DJANGO_DEV_STORE_METHOD=sqlite # ou "postgres"
DJANGO_DB_HOST=localhost
DJANGO_DB_NAME=note_db
DJANGO_DB_USER=note
DJANGO_DB_PASSWORD=CHANGE_ME
DJANGO_DB_PORT=
DJANGO_SECRET_KEY=CHANGE_ME
DJANGO_SETTINGS_MODULE="note_kfet.settings
2020-08-09 16:39:06 +00:00
NOTE_URL=localhost # URL où accéder à la note
DOMAIN=localhost # note.example.com
CONTACT_EMAIL=tresorerie.bde@localhost
# Le reste n'est utile qu'en production, pour configurer l'envoi des mails
NOTE_MAIL=notekfet@localhost
EMAIL_HOST=smtp.localhost
EMAIL_PORT=25
EMAIL_USER=notekfet@localhost
EMAIL_PASSWORD=CHANGE_ME
WIKI_USER=NoteKfet2020
WIKI_PASSWORD=CHANGE_ME
2020-03-11 14:54:12 +00:00
Ensuite on (re)bascule dans l'environement virtuel et on lance les migrations
2020-02-20 21:10:37 +00:00
2020-01-27 21:36:59 +00:00
$ source /env/bin/activate
2020-03-11 14:54:12 +00:00
(env)$ ./manage.py check # pas de bêtise qui traine
2020-01-27 21:36:59 +00:00
(env)$ ./manage.py makemigrations
(env)$ ./manage.py migrate
2020-08-10 16:26:45 +00:00
7. *Enjoy \o/*
2020-01-27 21:36:59 +00:00
2020-08-10 16:26:45 +00:00
### Installation avec Docker
2020-02-03 10:50:42 +00:00
Il est possible de travailler sur une instance Docker.
2020-08-10 16:26:45 +00:00
1. Cloner le dépôt là où vous voulez :
2020-02-03 10:50:42 +00:00
$ git clone git@gitlab.crans.org:bde/nk20.git
2020-08-10 16:26:45 +00:00
2. Copiez le fichier `.env_example` à la racine du projet vers le fichier `.env`,
et mettez à jour vos variables d'environnement
2020-03-11 14:54:12 +00:00
2020-08-10 16:26:45 +00:00
3. Dans le fichier `docker_compose.yml`, qu'on suppose déjà configuré,
ajouter les lignes suivantes, en les adaptant à la configuration voulue :
2020-02-03 10:50:42 +00:00
2020-08-10 16:26:45 +00:00
nk20:
build: /chemin/vers/nk20
volumes:
- /chemin/vers/nk20:/code/
env_file: /chemin/vers/nk20/.env
restart: always
labels:
- traefik.domain=ndd.example.com
- traefik.frontend.rule=Host:ndd.example.com
- traefik.port=8000
2020-02-03 10:50:42 +00:00
2020-08-10 16:26:45 +00:00
4. Enjoy :
2020-02-03 10:50:42 +00:00
$ docker-compose up -d nk20
2019-08-15 15:59:56 +00:00
2020-08-10 16:27:45 +00:00
### Lancer un serveur de développement
2019-07-07 21:31:20 +00:00
2020-02-20 21:10:37 +00:00
Avec `./manage.py runserver` il est très rapide de mettre en place
un serveur de développement par exemple sur son ordinateur.
2019-07-07 21:31:20 +00:00
2020-08-10 16:26:45 +00:00
1. Cloner le dépôt là où vous voulez :
2019-08-15 15:59:56 +00:00
2020-02-20 21:10:37 +00:00
$ git clone git@gitlab.crans.org:bde/nk20.git && cd nk20
2019-08-15 15:59:56 +00:00
2020-08-10 16:26:45 +00:00
2. Créer un environnement Python isolé
pour ne pas interférer avec les versions de paquets systèmes :
2020-02-20 21:10:37 +00:00
2020-08-10 16:26:45 +00:00
$ python3 -m venv venv
$ source venv/bin/activate
(env)$ pip install -r requirements/base.txt
2019-08-15 15:59:56 +00:00
2020-08-10 16:26:45 +00:00
3. Copier le fichier `.env_example` vers `.env` à la racine du projet et mettre à jour
ce qu'il faut
2020-03-11 14:54:12 +00:00
2020-08-10 16:26:45 +00:00
4. Migrations et chargement des données initiales :
2019-08-15 15:59:56 +00:00
(env)$ ./manage.py makemigrations
(env)$ ./manage.py migrate
2020-02-20 21:10:37 +00:00
(env)$ ./manage.py loaddata initial
2019-08-15 15:59:56 +00:00
2020-08-10 16:26:45 +00:00
5. Créer un super-utilisateur :
2019-08-15 15:59:56 +00:00
2020-02-20 21:10:37 +00:00
(env)$ ./manage.py createsuperuser
2020-01-21 21:03:59 +00:00
2020-08-10 16:26:45 +00:00
6. Enjoy :
2020-01-21 21:03:59 +00:00
2020-02-20 21:10:37 +00:00
(env)$ ./manage.py runserver 0.0.0.0:8000
2020-01-21 21:03:59 +00:00
2020-02-20 21:10:37 +00:00
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 !
2019-08-15 15:59:56 +00:00
2019-07-07 21:31:20 +00:00
## Documentation
2020-08-10 16:12:50 +00:00
Le cahier des charges initial est disponible [sur le Wiki Crans](https://wiki.crans.org/NoteKfet/NoteKfet2018/CdC).
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.
2020-03-11 14:54:12 +00:00
**Commentez votre code !**
2020-08-10 16:12:50 +00:00
La documentation plus haut niveau sur le développement est disponible sur [le Wiki associé au dépôt Git](https://gitlab.crans.org/bde/nk20/-/wikis/home).
## 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
django-admin makemessages -i env
```
Une fois les fichiers édités, vous pouvez compiler les nouvelles traductions avec
```bash
django-admin compilemessages
```