4.2.3.2. Cas 2: Configuration production

4.2.3.2.1. Procédure générale

La procédure suivante s’applique lorsqu’une PKI est déjà disponible pour fournir les certificats nécessaires.

Les étapes d’intégration des certificats à la solution Vitam sont les suivantes :

  • Générer les certificats avec les bons key usage par type de certificat
  • Déposer les certificats et les autorités de certifications correspondantes dans les bons répertoires.
  • Renseigner les mots de passe des clés privées des certificats dans le vault ansible environments/certs/vault-certs.yml
  • Utiliser le script Vitam permettant de générer les différents keystores.

Note

Rappel pré-requis : vous devez disposer d’une ou plusieurs PKI pour tout déploiement en production de la solution VITAM.

4.2.3.2.2. Génération des certificats

En conformité avec le document RGSV2 de l’ANSSI, il est recommandé de générer des certificats avec les caractéristiques suivantes:

4.2.3.2.2.1. Certificats serveurs

  • Key Usage
    • digitalSignature, keyEncipherment
  • Extended Key Usage
    • TLS Web Server Authentication

Les certificats serveurs générés doivent prendre en compte des alias « web » ( subjectAltName ).

Le subjectAltName des certificats serveurs ( deployment/environments/certs/server/hosts/* ) doit contenir le nom dns du service sur consul associé.

Exemple avec un cas standard: <composant_vitam>.service.<consul_domain>. Ce qui donne pour le certificat serveur de access-external par exemple:

X509v3 Subject Alternative Name:
    DNS:access-external.service.consul, DNS:localhost

Il faudra alors mettre le même nom de domaine pour la configuration de consul (fichier deployment/environments/group_vars/all/vitam_vars.yml, variable consul_domain )

Cas particulier pour ihm-demo et ihm-recette: il faut rajouter le nom dns qui sera utilisé pour requêter ces deux applications si celles-ci sont appelées directement en frontal en https.

4.2.3.2.2.2. Certificat clients

  • Key Usage
    • digitalSignature
  • Extended Key Usage
    • TLS Web Client Authentication

4.2.3.2.2.3. Certificats d’horodatage

  • Key Usage
    • digitalSignature, nonRepudiation
  • Extended Key Usage
    • Time Stamping

4.2.3.2.3. Intégration de certificats existants

Une fois les certificats et CA mis à disposition par votre PKI, il convient de les positionner sous environments/certs/.... en respectant la structure indiquée ci-dessous.

../../_images/arborescence_certs1.svg

Vue détaillée de l’arborescence des certificats

Astuce

Dans le doute, n’hésitez pas à utiliser la PKI de test (étapes de génération de CA et de certificats) pour générer les fichiers requis au bon endroit et ainsi voir la structure exacte attendue ; il vous suffira ensuite de remplacer ces certificats « placeholders » par les certificats définitifs avant de lancer le déploiement.

Ne pas oublier de renseigner le vault contenant les passphrases des clés des certificats: environments/certs/vault-certs.yml

Pour modifier/créer un vault ansible, se référer à la documentation sur cette url.

4.2.3.2.4. Intégration d’une application externe (cliente)

Dans le cas d’ajout de certificats SIA externes :

  • Déposer le certificat (.crt) de l’application client dans environments/certs/client-external/clients/external/
  • Déposer les CA du certificat de l’application (.crt) dans environments/certs/client-external/ca/
  • Editer le fichier environments/group_vars/all/vitam_security.yml et ajouter le(s) entrée(s) supplémentaire(s) (sous forme répertoire/fichier.crt, exemple: external/mon_sia.crt) dans la directive admin_context_certs pour que ceux-ci soient ajoutés aux profils de sécurité durant le déploiement de la solution logicielle VITAM.