2015-02-26 15:36:59 +01:00
# Certificat
2014-06-17 22:16:54 +02:00
2018-12-07 15:47:58 +01:00
Les certificats sont utilisés pour garantir la confidentialité et l'authenticité des communications entre un navigateur web et votre serveur. En particulier, il permet de protéger les visiteurs contre des attaquants qui chercheraient à usurper l'identité du serveur.
2014-06-17 22:16:54 +02:00
2017-07-30 00:25:13 +02:00
YunoHost fournit par défaut un certificat **auto-signé** , ce qui veut dire que c’ est votre serveur qui garantit la validité du certificat. C’ est suffisant **pour un usage personnel** , car vous pouvez avoir confiance en votre serveur, en revanche cela posera problème si vous comptez ouvrir l’ accès à votre serveur à des anonymes, par exemple pour héberger un site web.
2017-08-17 23:27:04 +02:00
En effet, les utilisateurs devront passer par un écran de ce type :
2014-06-18 15:17:41 +02:00
2016-03-22 09:14:24 +01:00
< img src = "/images/postinstall_error.png" style = "max-width:100%;border-radius: 5px;border: 1px solid rgba(0,0,0,0.15);box-shadow: 0 5px 15px rgba(0,0,0,0.35);" >
2014-06-18 15:17:41 +02:00
2017-08-17 23:27:04 +02:00
Cet écran revient à demander ** « Avez-vous confiance au serveur qui héberge ce site ? »**.
2015-02-26 15:36:59 +01:00
Cela peut effrayer vos utilisateurs (à juste titre).
2014-09-13 13:21:08 +02:00
2017-11-26 13:10:00 +01:00
Pour éviter cette confusion, il est possible d’ obtenir un certificat, reconnu directement par les navigateurs, signé par une autorité « connue » : **Let's Encrypt** , **Gandi** , **RapidSSL** , **StartSSL** , **Cacert** .
2018-01-10 09:39:51 +01:00
**Let's Encrypt** propose des certificats gratuits. Depuis la version 2.5, YunoHost permet d'installer directement un tel certificat depuis l'interface d'administration ou la ligne de commande. La suite du document détaille l'installation et la gestion d'un tel certificat. Vous pouvez également [installer un certificat d'une autre autorité que Let's Encrypt ](/certificate_custom_fr ).
2014-09-12 13:35:01 +02:00
2017-07-30 00:25:13 +02:00
### Installer un certificat Let's Encrypt
Avant de chercher à installer un certificat Let's Encrypt, assurez vous que
votre DNS est correctement configuré (votre.domaine.tld doit pointer sur l'IP
de votre serveur) et que votre site est accessible en HTTP depuis l'extérieur
2020-01-29 00:14:43 +01:00
(c.-à-d. qu'au moins le port 80 est correctement redirigé vers votre serveur).
2017-07-30 00:25:13 +02:00
#### Via l'interface d'administration web
2014-09-12 13:35:01 +02:00
2017-07-29 16:44:44 +02:00
Rendez-vous dans la partie 'Domaine' de l'interface d'administration, puis dans
2017-07-30 00:25:13 +02:00
la section dédiée à votre domaine. Vous trouverez un bouton 'Certificat SSL'.
2014-09-12 13:35:01 +02:00
2017-07-29 16:44:44 +02:00
![](./images/domain-certificate-button-fr.png)
2014-09-12 13:35:01 +02:00
2017-07-29 16:44:44 +02:00
Dans la section 'Certificat SSL', vous pourrez voir l'état actuel du certificat.
Si vous venez d'ajouter le domaine, il dispose d'un certificat auto-signé.
2014-09-12 13:35:01 +02:00
2017-07-29 16:44:44 +02:00
![](./images/certificate-before-LE-fr.png)
2014-09-12 13:35:01 +02:00
2017-07-30 00:25:13 +02:00
Si votre domaine est correctement configuré, il vous est alors possible de
passer à un certificat Let's Encrypt via le bouton vert.
2014-09-12 13:35:01 +02:00
2017-07-29 16:44:44 +02:00
![](./images/certificate-after-LE-fr.png)
2014-09-12 13:35:01 +02:00
2017-07-30 00:25:13 +02:00
Une fois l'installation effectuée, vous pouvez vous rendre sur votre domaine
via votre navigateur, en HTTPS, pour vérifier que votre certificat est bien
signé par Let's Encrypt. Le certificat sera renouvelé automatiquement tous les
trois mois environ.
2014-09-12 13:35:01 +02:00
2017-07-29 16:44:44 +02:00
![](./images/certificate-signed-by-LE.png)
2017-07-30 00:25:13 +02:00
2017-07-30 01:13:28 +02:00
#### Via la ligne de commande
2017-07-30 00:25:13 +02:00
Connectez-vous sur votre serveur en SSH.
Vous pouvez vérifier le statut actuel de votre certificat via
2017-08-17 23:27:04 +02:00
```bash
2017-07-30 00:25:13 +02:00
yunohost domain cert-status votre.domaine.tld
```
Installez le certificat Let's Encrypt via
2017-08-17 23:27:04 +02:00
```bash
2017-07-30 00:25:13 +02:00
yunohost domain cert-install votre.domaine.tld
```
2018-04-12 00:09:24 +02:00
Cette commande doit retourner :
2017-07-30 00:25:13 +02:00
2017-08-17 23:27:04 +02:00
```bash
2017-07-30 00:25:13 +02:00
Success! The SSOwat configuration has been generated
Success! Successfully installed Let's Encrypt certificate for domain DOMAIN.TLD!
```
Une fois l'installation effectuée, vous pouvez vous rendre sur votre domaine
via votre navigateur, en HTTPS, pour vérifier que votre certificat est bien
signé par Let's Encrypt. Le certificat sera renouvelé automatiquement tous les
trois mois environ.
##### En cas de problème
Si suite à une mauvaise manipulation, un certificat se retrouve dans une
situation fâcheuse (e.g. perte du certificat ou impossible de lire le
certificat), il est possible de repartir sur des bases propres en regénérant un
certificat auto-signé :
2017-08-17 23:27:04 +02:00
```bash
2017-07-30 00:25:13 +02:00
yunohost domain cert-install votre.domaine.tld --self-signed --force
```
Si YunoHost trouve que votre domaine est mal configuré quand bien même vous
avez bien vérifié votre configuration DNS et avez bien accès à votre serveur en
HTTP depuis l'extérieur, vous pouvez tenter :
- d'ajouter une ligne `127.0.0.1 votre.domaine.tld` au fichier `/etc/hosts` sur votre serveur ;
2018-04-12 00:09:24 +02:00
- si l'installation ne fonctionne toujours pas, désactiver les vérifications en ajoutant `--no-checks` à la commande `cert-install` .
2017-07-30 00:25:13 +02:00
2017-11-26 13:10:00 +01:00