Skip to content

Ouvrir les données de NewAglaé, l’Accélérateur Grand Louvre d'Analyses Elémentaires

License

Notifications You must be signed in to change notification settings

betagouv/euphrosyne

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

euphrosyne

Euphrosyne est une application web qui permet d'ouvrir et d'explorer les données de NewAglaé, l'Accélérateur Grand Louvre d'Analyses Elémentaires. Ce projet est basé sur Django, un framework web en Python, et sur des Web Components Javascript compilés avec Webpack.

Installation

Suivre les étapes suivantes pour installer les dépendances nécessaires au fonctionnement d'Euphrosyne :

  1. Installer les dépendances python en exécutant la commande suivante :
pip install -r requirements/[dev|prod].txt

Remplacer [dev|prod] par dev pour les environnements de développement et prod pour les environnements de production.

  1. Installer les dépendances javascript
npm install

Configuration

La configuration du projet se fait via des variables d'environnement. Celles-ci sont listées dans le fichier .env.example.

Le contenu du fichier peut-être copié dans un nouveau fichier .env pour paramétrer facilement l'environnement.

Nom de la variable Description
CORS_ALLOWED_ORIGINS Valeur du header Access-Control-Allow-Origin pour les réponses sur les endpoints de l'api REST
DJANGO_SETTINGS_MODULE Chemin Python vers le module settings Django.
DB_* Variables relatives à la configuration de la base de données.
DJANGO_SECRET_KEY Clé secrète utilisée par Django pour la signature cryptographique. Est également utilisé pour signer les tokens JWT (Euphrosyne Tools API).
DJANGO_DEBUG Optionnel. Mode debug de Django.
ELASTICSEARCH_HOST Hôte de l'instance Elasticsearch (catalogue de données)
ELASTICSEARCH_USERNAME Credentials pour l'instance Elasticsearch (catalogue de données)
ELASTICSEARCH_PASSWORD Credentials pour l'instance Elasticsearch (catalogue de données)
EMAIL_HOST Configuration du service d'e-mail.
EMAIL_PORT "
EMAIL_HOST_USER "
EMAIL_HOST_PASSWORD "
EUPHROSYNE_TOOLS_API_URL URL de Euphrosyne Tools
DEFAULT_FROM_EMAIL Adresse mail de l'expéditeur par défaut.
DEFAULT_FROM_EMAIL Optionnel. Date limite à partir de laquelle les utilisateurs doivent accepter les nouvelles Conditions Générales d'Utilisation (CGU). Si un utilisateur n'a pas accepté les CGU après cette date, il sera redirigé vers la page d'acceptation des CGU.
MATOMO_SITE_ID ID du site sur Matomo.
ORCID_USE_SANDBOX Choix de l'environnment pour l'authentification ORCID. Si égale à 'true', l'environnement sandbox est utilisé. Default to false.
SITE_URL L'URL de cette instance d'Euphrosyne.
SENTRY_DSN Optionnel. Sentry DSN. Si omis, Sentry ne sera pas utilisé.
SENTRY_ENVIRONMENT Tag utilisé pour filtrer les événements Sentry. Choix possibles : 'production', 'staging' or 'dev'.
SOCIAL_AUTH_ORCID_KEY Credentials de l'application ORCID pour authentifier les utilisateurs.
SOCIAL_AUTH_ORCID_SECRET "

Développement

Pour lancer le serveur de développement Django, exécutez la commande suivante :

./manage.py runserver

Cela va lancer le serveur sur http://localhost:8000.

Pour créer les bundles des fichiers relatifs au frontend en mode développement, exécutez la commande suivante :

Pour créer les bundles des fichiers relatifs au frontend en mode développement, exécutez la commande suivante :

npm run build:dev

Cela va lancer Webpack et créer les fichiers javascript et css nécessaires pour le frontend.

Frontend

Gestion des modules javascript par Webpack

Le frontend d'Euphrosyne est géré par Webpack, un outil de gestion de modules javascript. Les fichiers javascript sont compilés à partir des fichiers présents dans les dossiers ./**/assets/js/pages/*.js. Les fichiers de style (css, scss, ...) importés dans le code javascript sont regroupés dans un fichier <filename>.css.

Pour faire référence aux fichiers javascript et css dans un template Django, vous pouvez utiliser les balises script et link suivantes :

<script src="{% static 'pages/<filename>.js' %}"></script>
<link rel="stylesheet" type="text/css" href="{% static "<filename>.css" %}">