Le dossier `deployment/roles` contient des *roles*, c'est-à-dire des élément d'installation exécutés par ansible sur le serveur. Le fichier `playbook.yml` définit l'ordre dans lequel ansible lance les roles.
-`common` installe le paquet debian.
-`nginx` installe le reverse proxy.
-`certbot` ajoute le certificat https.
-`archive` :
- lance la commande git archive qui crée un tar.gz à partir du dossier de la webapp ;
- met cette archive dans `deployment/roles/archive/files` ;
- copie l'archive dans le dossier `opt` du serveur ;
- extraie l'archive dans le serveur : le code de la webapp est donc copiée dans le serveur.
-`pip` installe les librairies Python nécessaires sur le serveur.
-`run` lance l'application Flask.
-`mongodb` installe mongodb sur le serveur.
L'activation de l'ensemble des roles est automatisée avec le script `run_playbook.sh`.
- copier/coller le main.yml de `princevault/deployment` dans `deployment/group_vars/all`, le renommer et vérifier que le bon tag est renseigner dans `application_release_tag`.
- Rôle ngnx. `deployment/roles/nginx/tasks/main.yml` : compléter les fichiers de `/etc/nginx/sites-enabled/`. Pour ajouter une autre appli, faire une variable `domain2`.
- Rôle certbot.
- Rôle archive.
- Rôle pip.
- Rôle mongodb.
4. Dans `datascience`, *activer le venv* :
- copier/coller le param.yml de `princevault/datascience` dans `datascience/actes-princiers/conf/local`
- installer les librairies : `pip install -r ./actes-princiers/src/requirements.txt`
- récupéer les dernières données : `./data_registry_update.sh`
- effacer le contenu de 02_intermediate`./clean_intermediate_data.sh`
- dans `datascience/actes-princiers` : `kedro run --tags="etl_transform"`
- (scp -r datascience/ <user>@<domain>:~/)
-`kedro run --tags="populate_database"`
5. Dans `deployment`, *activer le venv* :
- Lancement de l'application (`launch_playbook.yml`) avec `./launch_application.sh`
7. Publier l'application en cas de mise à jour : `deployment/publish.sh`