====== EasyRSA ====== ===== Installation ===== ==== Via le paquet Debian ==== sudo apt install easy-rsa make-cadir /etc/eesyrsa mkdir /var/lib/easyrsa cat << EOF > /usr/local/sbin/easyrsa #!/bin/bash export EASYRSA=/etc/easyrsa export EASYRSA_PKI=/var/lib/easyrsa cd "\$EASYRSA" ./easyrsa "\$@" exit \$? EOF chmod 755 /usr/local/sbin/easyrsa ==== Depuis les sources ==== apt install openssl rsync wget TMP_DIR=$(mktemp --directory) cd $TMP_DIR wget -O easyrsa.tgz https://github.com/OpenVPN/easy-rsa/releases/download/v3.1.7/EasyRSA-3.1.7.tgz tar xzvf easyrsa.tgz mv EasyRSA* /usr/local/share/easyrsa chown root:root -R /usr/local/share/easyrsa mkdir /etc/easyrsa for i in easyrsa x509-types/ vars.example openssl-easyrsa.cnf do rsync -av /usr/local/share/easyrsa/$i /etc/easyrsa/$i done cp /etc/easyrsa/vars.example /etc/easyrsa/vars cat << EOF > /usr/local/sbin/easyrsa #!/bin/bash export EASYRSA=/etc/easyrsa export EASYRSA_PKI=/var/lib/easyrsa cd "\$EASYRSA" ./easyrsa "\$@" exit \$? EOF chmod 755 /usr/local/sbin/easyrsa rm -fr $TMP_DIR Le fichier ''/etc/easyrsa/vars'' contient des informations de configuration importante, comme par exemple la durée de validité des certificats générés (''EASYRSA_CERT_EXPIRE'', 825 jours par défaut). ===== Initialisation de la CA ===== easyrsa init-pki EASYRSA_CA_EXPIRE=365 easyrsa build-ca easyrsa show-ca ===== Générer un certificat pour un serveur ===== easyrsa build-server-full host.domain.tld nopass Les fichiers générés seront récupérables ici : * ''/var/lib/easyrsa/private/host.domain.tld.key'' * ''/var/lib/easyrsa/issued/host.domain.tld.crt'' * ''/var/lib/easyrsa/req/host.domain.tld.req'' (CSR) Pour ajouter un nom de domaine alternatif au certificat, utiliser le paramètre ''--subject-alt-name'' (**à position avant l'argument ''build-server-full''**). Exemple : easyrsa --subject-alt-name=DNS:alt.domain.tld build-server-full host.domain.tld nopass ===== Générer un certificat pour un client ===== * Générer la clé privée + une demande de certificat (CSR) : easyrsa gen-req myclient * Approuver la demande de certificat (CSR) et le générer : easyrsa sign-req client myclient Les fichiers générés seront récupérables ici : * ''/var/lib/easyrsa/private/myclient.key'' * ''/var/lib/easyrsa/issued/myclient.crt'' * ''/var/lib/easyrsa/reqs/myclient.req'' (CSR) ===== Révoquer un certificat et générer la CRL ===== * Révoquer le certificat : easyrsa revoke myclient * Générer la CRL : easyrsa gen-crl La CRL est récupérable dans le fichier ''/var/lib/easyrsa/crl.pem''. ===== Exécution en mode batch ===== Pour une exécution en mode batch, sans avoir à répondre à des questions et en fournissant les réponses attendues via des variables d'environnement, vous pouvez : * Générer la clé privée + une demande de certificat (CSR) : EASYRSA_PASSOUT=env:KEY_PWD KEY_PWD=myclient_secret easyrsa --batch gen-req myclient * Approuver la demande de certificat (CSR) et le générer : EASYRSA_PASSIN=env:CA_PWD CA_PWD=ca_secret easyrsa --batch sign-req client myclient * Révoquer le certificat : EASYRSA_PASSIN=env:CA_PWD CA_PWD=ca_secret easyrsa --batch revoke myclient * Générer la CRL : EASYRSA_PASSIN=env:CA_PWD CA_PWD=ca_secret easyrsa --batch gen-crl