Code source wiki de Accueil Hypercerts

Version 21.1 par Matthieu Manginot le 22/07/2020 - 16:32

Masquer les derniers auteurs
dufour18 4.1 1 Vous cherchez à délivrer aux étudiants de votre université des attestations de réussite dématérialisées ? Hypercerts vous permettera de générer et envoyer des attestations officielles, numériques, et infalsifiable.
Benjamin Seclier 1.1 2
dufour18 4.1 3 Ces dernières pourront être envoyées par mail, déposées dans le nuage, et même être certifiées authentiques et intègres grâce à une blockchain dédiée.
Benjamin Seclier 1.1 4
dufour18 4.1 5 Une fois l'application connectée à Apogée et au LDAP, les gestionnaires de composantes pourront demander la génération et l'envoi des attestations de réussite en un clic.
6
dufour18 3.1 7 {{info}}
Matthieu Manginot 9.1 8 La version 1.0.x est une beta. Bien que le cœur de l'application soit fonctionnel, les dépôts de documents dans les coffres digisposte et la certification cryptographique sont en cours de dévelopement actif.
dufour18 3.1 9 {{/info}}
Benjamin Seclier 1.1 10
Matthieu Manginot 7.1 11 == Prérequis ==
dufour18 3.1 12
dufour18 5.1 13 Hypercerts est une application Java qui se connecte à Apogée et au LDAP. Elle requiert l'utilisation d'une base MariaDB pour son fonctionnement interne. Elle se déploie sur des serveurs comme une application SpringBoot classique. Le WAR pourra être pris en charge par un tomcat et servir les utilisateur•ices via l'URL configuré.
dufour18 3.1 14
dufour18 2.1 15 |=(((
dufour18 3.1 16 Technologie
dufour18 2.1 17 )))|=(((
dufour18 3.1 18 Version
dufour18 2.1 19 )))
20 |(((
dufour18 3.1 21 JDK
dufour18 2.1 22 )))|(((
dufour18 3.1 23 11+
dufour18 2.1 24 )))
dufour18 3.1 25 |(% colspan="1" %)(((
26 SpringBoot
27 )))|(% colspan="1" %)(((
28 2.3
29 )))
30 |(% colspan="1" %)(((
31 Vaadin (Frontend)
32 )))|(% colspan="1" %)(((
33 14
34 )))
dufour18 2.1 35 |(((
dufour18 3.1 36 Tomcat
dufour18 2.1 37 )))|(((
dufour18 3.1 38 9+
39 )))
40 |(% colspan="1" %)(((
41 MariaDB
42 )))|(% colspan="1" %)(((
43 14+
44 )))
45 |(% colspan="1" %)(((
46 Maven
47 )))|(% colspan="1" %)(((
48 3.6+
49 )))
50 |(% colspan="1" %)(((
51 Connection Apogée
52 )))|(% colspan="1" %)(((
dufour18 2.1 53 \\
54 )))
dufour18 3.1 55 |(% colspan="1" %)(((
56 Connection Apogée via WS
57 )))|(% colspan="1" %)(((
dufour18 2.1 58 \\
dufour18 3.1 59 )))
60 |(% colspan="1" %)(((
61 Connection LDAP
62 )))|(% colspan="1" %)(((
dufour18 2.1 63 \\
64 )))
dufour18 3.1 65 |(% colspan="1" %)(((
66 Docker (optionnel)
67 )))|(% colspan="1" %)(((
68 docker-compose 3
69 )))
Benjamin Seclier 1.1 70
dufour18 4.1 71 == Téléchargement des sources ==
72
73 Provisoirement, les sources de l'application peuvent être téléchargées à [[cet endroit>>url:http://download-sig.univ-lorraine.fr/home/download-sig/public/hypercerts||shape="rect"]].
74
dufour18 2.1 75 == Personalisation d'Hypercerts ==
76
Matthieu Manginot 12.1 77 === Configuration l'application ===
dufour18 4.1 78
Matthieu Manginot 10.1 79 Créer et compléter un fichier **application.yaml** à la racine du projet sur le modèle de **application-sample.yaml**
80
Matthieu Manginot 19.1 81 === **Éléments de configuration important ** ===
82
83 ==== Property //app.production// ====
84
85 Pour les tests, mettre **app.production** à false pour obtenir une année supplémentaire (N-2) pour la génération, ainsi des diplômes avec résultats seront plus facilement trouvables.
86
87 En étant à false, cette property autorise également l'interception de tout les mails applicatifs.
88
89 ==== **Envoi de mail** ====
90
Matthieu Manginot 15.1 91 (% style="color: rgb(0,51,102);" %)__**Sur votre environnement de test/développement**, pour empêcher l'envoi de mails de test en réel, il est conseillé :__
Matthieu Manginot 11.1 92
93 * d'utiliser un mail catcher ([[https:~~/~~/mailcatcher.me/>>url:https://mailcatcher.me/||shape="rect"]]) en remplacement de votre smtp
94 * ou de configurer l'application pour intercepter tout les mails applicatifs avec ces valeurs :
95 ** **app.production** à false
96 ** **spring.mail.intercept.active** à true
97 ** et **spring.mail.intercept.mails** contenant une ou plusieurs adresses de réception des mails
98
Matthieu Manginot 20.1 99 ==== WebServices Apogée ====
100
Matthieu Manginot 21.1 101 {{status colour="Yellow" title="TODO"/}}
Matthieu Manginot 20.1 102
Matthieu Manginot 12.1 103 === Configurer et lancer le projet dans Eclipse ===
104
105 * Importer le projet Maven dans eclipse.
Matthieu Manginot 19.1 106 * Lorsque la configuration est terminée, démarrer l'application en faisant un clic droit sur {{code language="none"}}fr.univlorraine.hypercerts.Application.java{{/code}} et en choisissant 'Run As / Java Application'.
Matthieu Manginot 12.1 107
Matthieu Manginot 14.1 108 === Customisation des services ===
109
Matthieu Manginot 18.1 110 Plusieurs services sont personnalisables en fonction de votre environnement.
Matthieu Manginot 14.1 111
Matthieu Manginot 17.1 112 Sous fr.univlorraine.hypercerts.apogee.service.customs :
Matthieu Manginot 16.1 113
Matthieu Manginot 17.1 114 * ApogeeUserServiceCustomExample
Matthieu Manginot 18.1 115 ** Personnalisation de la récupération des adresses mails des utilisateurs Apogée à partir de l'uid LDAP
Matthieu Manginot 17.1 116 * BlocageServiceCustomExample
Matthieu Manginot 18.1 117 ** Personnalisation de la récupération des blocages/interdits à partir d'un code étudiant Apogée
Matthieu Manginot 17.1 118 * ComposanteServiceCustomExample
Matthieu Manginot 18.1 119 ** Personnalisation de la récupération :
120 *** de toutes les composantes
121 *** des composantes pour un utilisateur à partir de l'uid LDAP
122 *** du nombre de composantes pour un utilisateur à partir de l'uid LDAP
Matthieu Manginot 16.1 123
Matthieu Manginot 21.1 124 {{status colour="Yellow" title="TODO"/}}
125
Matthieu Manginot 17.1 126 === Customisation de Digiposte ===
127
128 //Documentation à venir.//
129
Matthieu Manginot 12.1 130 === Tâches Maven ===
131
132 * Lancer l'application (hors d'un IDE) :
133
134 {{code language="bash" theme="Eclipse"}}
135 mvn spring-boot:run
136 {{/code}}
137
138 * Lancer les tests :
139
140 {{code language="bash" theme="Eclipse"}}
141 mvn verify
142 {{/code}}
143
144 * Créer le package pour production :
145
146 {{code language="bash" theme="Eclipse"}}
147 mvn clean package -Pproduction
148 {{/code}}
149
Matthieu Manginot 13.1 150 === Makefile ===
151
152 Un Makefile est également disponible. A la racine, utilisez `make help` pour obtenir les commandes disponibles.
153
Matthieu Manginot 14.1 154 == Tests unitaires ==
dufour18 4.1 155
Matthieu Manginot 13.1 156 Pour s'assurez que les résultats d'admission de vos étudiants soient bien correct, et afin d'éviter les faux positifs (donc envoyer une attestation de réussite à un•e étudiant•e non reçu•e aux examens), vous pouvez ajouter vos jeux de données
dufour18 4.1 157
Matthieu Manginot 14.1 158 {{status colour="Red" title="FONCTIONNEMENT A PRECISER"/}}
159
dufour18 5.1 160 == Mise en service de l'application ==
dufour18 2.1 161
dufour18 4.1 162 \\
163
Benjamin Seclier 1.1 164 {{section}}
165 {{column width="60%"}}
166 {{recently-updated/}}
167 {{/column}}
168
dufour18 2.1 169 {{column width="5%"}}
170 \\
171 {{/column}}
Benjamin Seclier 1.1 172
173 {{column width="35%"}}
174 ====== Navigate space ======
175
176 {{locationSearch reference="WebHome"/}}
177
178 {{pagetree/}}
179 {{/column}}
180 {{/section}}