Ce tutoriel explique comment compiler Kritis Signer et comment l'utiliser pour rechercher les failles dans des images de conteneurs avant de créer des attestations d'autorisation binaire.
Présentation
Kritis Signer est un outil de ligne de commande Open Source qui permet de créer des attestations pour l'autorisation binaire en fonction d'une règle que vous configurez. Vous pouvez également utiliser Kritis Signer pour créer des attestations après avoir vérifié une image pour détecter les failles identifiées par Artifact Analysis.
De plus, Cloud Build peut exécuter Kritis Signer en tant que compilateur personnalisé dans un pipeline de compilation.
Dans ce tutoriel, vous allez effectuer une compilation unique du compilateur personnalisé Kritis Signer, puis exécuter des exemples de pipelines de compilation. Chaque exemple de pipeline contient les étapes de compilation suivantes :
- Créer un exemple d'image de conteneur.
- Transférer l'image vers Container Registry.
- Vérifier et signer l'image : utiliser Kritis Signer pour créer une attestation basée sur la stratégie.
À l'étape de compilation du processus de vérification de chaque pipeline, Kritis Signer effectue les opérations suivantes :
- Analyse l'image nouvellement créée avec Artifact Analysis et récupère une liste de failles.
- Vérifie la liste des failles par rapport aux règles de signature des failles dans la stratégie, puis effectue les opérations suivantes :
- Si toutes les failles identifiées respectent les règles de signature des failles, Kritis Signer crée l'attestation.
- Si l'une des failles identifiées ne respecte pas les règles de signature des failles, Kritis Signer ne crée pas l'attestation.
Au moment du déploiement, l'outil d'application de l'autorisation binaire recherche une attestation vérifiable. Sans cela, l'outil d'application bloque le déploiement de l'image.
Ce tutoriel explique également comment exécuter Kritis Signer en mode test uniquement dans un pipeline Cloud Build. Dans ce mode, Kritis Signer ne crée pas d'attestation. Il vérifie uniquement si les résultats de faille respectent les règles de signature des failles dans la stratégie. Si c'est le cas, l'étape de compilation de Kritis Signer réussit et le pipeline continue de s'exécuter. Sinon, l'étape échoue et le pipeline se ferme.
Objectifs
Dans ce tutoriel, vous allez effectuer les opérations suivantes :
- Configurer Kritis Signer en tant que compilateur personnalisé Cloud Build.
- Afficher une stratégie contenant des règles de signature des failles.
- Exécuter Kritis Signer dans des attestations de création basées sur les résultats de l'analyse des failles.
- Exécuter Kritis Signer en mode test uniquement.
Coûts
Ce tutoriel utilise les produits Google Cloud suivants.
- Container Registry
- Artifact Analysis
- Cloud Build
- Cloud Key Management Service
Utilisez le simulateur de coût pour générer une estimation des coûts en fonction de votre utilisation prévue.
Avant de commencer
Dans cette section, vous allez effectuer une configuration unique du système.
Configurer votre environnement
Stockez votre projet Google Cloud dans une variable d'environnement.
export PROJECT_ID=PROJECT_ID
Remplacez PROJECT_ID par votre projet Google Cloud.
Définissez l'ID du projet par défaut sur votre projet Google Cloud :
gcloud config set project $PROJECT_ID
Stockez le numéro de projet dans une variable d'environnement pour les étapes suivantes :
export PROJECT_NUMBER=$(gcloud projects list --filter="${PROJECT_ID}" \ --format="value(PROJECT_NUMBER)")
Activez les API :
Pour vous assurer que les services requis pour ce guide sont activés, exécutez la commande suivante :
gcloud services enable \ cloudbuild.googleapis.com \ containerregistry.googleapis.com \ containerscanning.googleapis.com \ cloudkms.googleapis.com
Configurer les rôles IAM
Exécutez les commandes suivantes pour configurer les rôles suivants sur le compte de service Cloud Build :
containeranalysis.notes.editor
: ajoute le rôle Éditeur de notes Artifact Analysis pour gérer le certificateur.containeranalysis.notes.occurrences.viewer
: ajoute le rôle Lecteur d'occurrences Artifact Analysis pour les notes afin de gérer à la fois les occurrences de failles et d'attestation.roles/containeranalysis.occurrences.editor
: ajoute le rôle Éditeur d'occurrences Artifact Analysis pour créer des occurrences d'attestation dans Artifact Analysis.cloudkms.signer
: ajoute le rôle Signataire de CryptoKeys Cloud KMS qui permet au compte de service d'accéder au service de signature Cloud KMS.gcloud projects add-iam-policy-binding $PROJECT_ID --member serviceAccount:$PROJECT_NUMBER@cloudbuild.gserviceaccount.com --role roles/containeranalysis.notes.editor gcloud projects add-iam-policy-binding $PROJECT_ID --member serviceAccount:$PROJECT_NUMBER@cloudbuild.gserviceaccount.com --role roles/containeranalysis.notes.occurrences.viewer gcloud projects add-iam-policy-binding $PROJECT_ID --member serviceAccount:$PROJECT_NUMBER@cloudbuild.gserviceaccount.com --role roles/containeranalysis.occurrences.editor gcloud projects add-iam-policy-binding $PROJECT_ID --member serviceAccount:$PROJECT_NUMBER@cloudbuild.gserviceaccount.com --role roles/cloudkms.signer
Configurer le compilateur personnalisé Kritis Signer
Dans cette section, vous allez effectuer une configuration unique du compilateur personnalisé Kritis Signer. Une fois que vous avez obtenu, compilé et transféré Kritis Signer, vous pouvez ensuite l'utiliser dans n'importe quel pipeline Cloud Build.
Cette section vous explique comment :
- cloner le dépôt Kritis ;
- créer le compilateur personnalisé Cloud Build Kritis Signer ;
- transférer Kritis Signer vers Container Registry pour le rendre disponible en tant qu'étape de compilation Cloud Build.
Exécutez les commandes suivantes pour obtenir le code et les fichiers de configuration utilisés dans ce guide :
Cloner le dépôt Kritis :
git clone https://github.com/grafeas/kritis.git
Ce dépôt contient les éléments suivants :
- Le code source de Kritis, incluant également Kritis
- Un fichier de configuration Cloud Build utilisé par Cloud Build pour créer le compilateur personnalisé Kritis Signer
- Un exemple de stratégie contenant des règles de signature des failles.
- Des exemples de fichiers de configuration Cloud Build. Chaque fichier de configuration utilise Kritis Signer dans un pipeline d'analyse des failles.
Accédez au répertoire
kritis/
:cd kritis
Créez et enregistrez le compilateur personnalisé Kritis Signer.
Cette étape de configuration unique crée le compilateur personnalisé Kritis Signer et l'enregistre auprès de Cloud Build. Une fois enregistré, le compilateur personnalisé peut être utilisé dans n'importe quel pipeline Cloud Build.
gcloud builds submit . --config deploy/kritis-signer/cloudbuild.yaml
Afficher une stratégie sexistante
Cette section présente un exemple de stratégie Kritis Signer.
Cette règle configure Kritis Signer pour demander à Artifact Analysis d'analyser l'image à la recherche de failles. Une fois l'analyse terminée, Kritis Signer vérifie les résultats de failles renvoyés par rapport aux règles de signature des failles dans la stratégie.
Vous pouvez modifier les règles de signature des failles dans cette stratégie pour créer une attestation basée sur les éléments suivants :
- Niveaux de gravité des failles identifiées.
- Failles spécifiques
Vous pouvez également définir la stratégie pour créer sans condition (ALLOW_ALL
) ou ne pas créer (BLOCK_ALL
) d'attestation.
Pour afficher la règle Kritis Signer, exécutez la commande suivante :
cat samples/signer/policy-strict.yaml
La règle se présente comme suit :
Où :
maximumUnfixableSeverity
etmaximumFixableSeverity
définissent les seuils de gravité des failles et expositions communes ("Common Vulnerabilities and Exposures" ou CVE) auxquels Kritis Signer crée des attestations.maximumUnfixableSeverity
définit le seuil de gravité pour lequel aucun correctif n'est disponible actuellement.maximumFixableSeverity
définit le seuil de gravité pour lequel un correctif est actuellement disponible.maximumUnfixableSeverity
etmaximumFixableSeverity
peuvent être définis sur l'un des niveaux de gravité suivants :CRITICAL
HIGH
MEDIUM
LOW
Pour en savoir plus sur les niveaux de gravité, consultez la section Niveaux de gravité.
Vous pouvez également définir
maximumUnfixableSeverity
etmaximumFixableSeverity
sur les éléments suivants :BLOCK_ALL
: l'attestation n'est pas créée si une faille est détectée.ALLOW_ALL
: l'attestation est toujours créée.
allowlistCVEs
est une liste de CVE spécifiques à ajouter à la liste d'autorisation. Kritis Signer ignore les failles CVE de cette liste lors de l'évaluation de la création d'une attestation. Chaque entrée de la liste d'autorisation doit correspondre exactement au nom de la note Artifact Analysis pour la faille CVE. Apprenez-en plus sur les sources de failles Artifact Analysis. Pour en savoir plus sur les notes, consultez la page Stockage de métadonnées.
Créer une clé de signature Cloud KMS
Les clés Cloud Key Management Service sont utilisées pour créer l'attestation.
Créez un trousseau de clés Cloud KMS nommé KEY_RING :
gcloud kms keyrings create KEY_RING \ --location global
Dans ce trousseau, créez une clé Cloud KMS appelée KEY_NAME :
gcloud kms keys create KEY_NAME \ --keyring KEY_RING \ --location global \ --purpose "asymmetric-signing" \ --default-algorithm "rsa-sign-pkcs1-2048-sha256"
Stockez l'algorithme de condensé et la clé Cloud KMS dans une variable d'environnement pour les prochaines étapes :
export KMS_DIGEST_ALG=SHA256 export KMS_KEY_NAME=projects/$PROJECT_ID/locations/global/keyRings/KEY_RING/cryptoKeys/KEY_NAME/cryptoKeyVersions/1
Définir un nom de note
Toutes les attestations font référence à une note Artifact Analysis. Kritis Signer crée automatiquement une note pour un nom donné. Vous pouvez également réutiliser des noms de notes existants.
export NOTE_ID=my-signer-note
export NOTE_NAME=projects/${PROJECT_ID}/notes/${NOTE_ID}
Créer des attestations à l'aide de Kritis Signer dans un pipeline Cloud Build
Cette section explique comment utiliser le compilateur personnalisé Kritis Signer pour créer des attestations d'autorisation binaire basées sur les résultats de l'analyse des failles.
Les étapes suivantes montrent comment Kritis Signer utilise les exemples de fichiers de configuration de compilation du dépôt Kritis Signer. Chaque exemple de fichier de configuration contient les étapes de compilation suivantes :
- Une étape
docker build
qui crée une image de conteneur Docker - Une étape
docker push
qui transfère l'image de conteneur nouvellement créée vers Container Registry Une étape
vulnsign
qui vérifie et signe l'image du conteneur en effectuant les opérations suivantes :- Elle attend que Artifact Analysis renvoie les résultats des failles sur la nouvelle image de conteneur.
- Elle vérifie les résultats en fonction des règles de signature des failles.
- Elle crée l'attestation si les résultats respectent les règles sur les failles.
Vous envoyez chacun de ces exemples de compilation à Cloud Build. Chaque compilation produit un résultat de faille :
- Exemple d'échec : le résultat de faille enfreint les règles de signature de failles. Cette compilation échoue et aucune attestation n'est créée.
- Exemple de réussite : le résultat de faille respecte les règles de signature de failles. Cette compilation réussit et une attestation est créée.
Envoyer l'exemple d'échec de la compilation
Dans cette section, vous allez créer une image de conteneur et l'analyser pour détecter les failles.
La compilation échoue, car l'image de conteneur est basée sur un instantané spécifique de Debian 10, qui contient un certain nombre de failles avec le niveau de gravité HIGH
. Ces failles ne respectent pas les règles de signature de failles. Par conséquent, le compilateur ne produit pas d'attestation.
(Facultatif) Affichez le fichier de règles de signature des failles pour le cas d'échec.
cat samples/signer/policy-strict.yaml
Envoyez la compilation :
gcloud builds submit \ --substitutions=_KMS_KEY_NAME=$KMS_KEY_NAME,_KMS_DIGEST_ALG=$KMS_DIGEST_ALG,_NOTE_NAME=$NOTE_NAME \ --config=samples/signer/cloudbuild-bad.yaml samples/signer
Un résultat semblable à celui-ci s'affiche :
"ERROR: (gcloud.builds.submit) build BUILD_ID completed with status "FAILURE"
Enregistrez l'ID de la dernière compilation :
export BUILD_ID=$(gcloud builds list --limit=1 --format="value('ID')")
Vérifiez le résultat :
gcloud storage cat gs://${PROJECT_NUMBER}.cloudbuild-logs.googleusercontent.com/log-${BUILD_ID}.txt | grep "does not pass VulnzSigningPolicy"
Envoyer l'exemple de réussite de la compilation
Dans cette section, vous allez créer une image de conteneur contenant des failles qui n'enfreignent pas les règles de signature des failles. Dans ce cas, le compilateur personnalisé Kritis Signer crée une attestation.
Pour envoyer l'exemple de réussite de la compilation dans Cloud Build, procédez comme suit :
(Facultatif) Affichez le fichier de règles de signature des failles pour le cas de réussite.
cat samples/signer/policy-loose.yaml
Envoyez la compilation :
gcloud builds submit \ --substitutions=_KMS_KEY_NAME=$KMS_KEY_NAME,_KMS_DIGEST_ALG=$KMS_DIGEST_ALG,_NOTE_NAME=$NOTE_NAME \ --config=samples/signer/cloudbuild-good.yaml samples/signer
Enregistrez l'ID de la dernière compilation :
export BUILD_ID=$(gcloud builds list --limit=1 --format="value('ID')")
Vérifiez le résultat :
gcloud builds describe $BUILD_ID | grep status
Utiliser Kritis Signer en mode test uniquement
Cette section explique comment utiliser Kritis Signer en mode check-only
. Dans ce mode, Kritis Signer ne crée pas d'attestation. Il vérifie simplement que les failles de l'image avant d'effectuer ou non l'étape de compilation en fonction des règles de signature des failles.
Envoyer l'exemple d'échec de la compilation
(Facultatif) Affichez le fichier de règles de signature des failles pour le cas d'échec.
cat samples/policy-check/policy-strict.yaml
Dans l'étape de compilation de Kritis Signer, notez que l'option
mode
est définie surcheck-only
.Envoyez la compilation :
gcloud builds submit \ --config=samples/policy-check/cloudbuild-bad.yaml samples/policy-check
Notez que la compilation échoue.
Enregistrez l'ID de la dernière compilation :
export BUILD_ID=$(gcloud builds list --limit=1 --format="value('ID')")
Vérifiez le résultat :
gcloud storage cat gs://${PROJECT_NUMBER}.cloudbuild-logs.googleusercontent.com/log-${BUILD_ID}.txt | grep "does not pass VulnzSigningPolicy"
Envoyer l'exemple de réussite de la compilation
(Facultatif) Affichez le fichier de règles de signature des failles pour le cas de réussite.
cat samples/policy-check/policy-loose.yaml
Envoyez la compilation :
gcloud builds submit \ --config=samples/policy-check/cloudbuild-good.yaml samples/policy-check
Enregistrez l'ID de la dernière compilation :
export BUILD_ID=$(gcloud builds list --limit=1 --format="value('ID')")
Vérifiez le résultat :
gcloud builds describe $BUILD_ID | grep status
Créer un certificateur
Pour créer une stratégie nécessitant les attestations que vous créez à l'aide de la méthode décrite dans ce guide, vous devez d'abord créer un certificateur.
Pour créer un certificateur, procédez comme suit :
Récupérez le matériel de clé publique à partir de la clé Cloud KMS que vous avez créée précédemment dans ce guide :
gcloud kms keys versions get-public-key 1 \ --key KEY_NAME \ --keyring KEY_RING \ --location global \ --output-file OUTPUT_PATH
KEY_NAME
: nom de la cléKEY_RING
: nom du trousseau de clés.OUTPUT_PATH
: chemin d'accès au fichier (par exemple,my-key.pem
)
Créez un certificateur à l'aide du matériel de clé publique dans le fichier et de la note que vous avez créée précédemment dans ce guide. Vous pouvez créer un certificateur via la console Google Cloud ou gcloud CLI.
Créez une stratégie exigeant des attestations et spécifiez le certificateur que vous avez créé dans cette section. Vous pouvez créer une règle via la console Google Cloud ou gcloud CLI.
Créez un certificat
Pour créer une attestation à l'aide de votre certificateur, consultez la page Créer une attestation à l'aide de Cloud KMS.
Effectuer un nettoyage
Pour nettoyer les ressources utilisées dans ce document, vous pouvez supprimer le projet :
gcloud projects delete ${PROJECT_ID}
Étape suivante
- Documentation de Kritis Signer sur GitHub
- Présentation de l'autorisation binaire
- Créez des certificateurs via Google Cloud Console ou l'outil de ligne de commande.
- Configurez une stratégie pour exiger des attestations via Google Cloud Console ou l'outil de ligne de commande.
- Créer des attestations avec Voucher
- Artifact Analysis et analyse des failles
- Compilateurs Cloud Build de la communauté et personnalisés