updated documentation in Dockerfile und Jenkinsfile and updated to --template "html"
This commit is contained in:
61
Jenkinsfile
vendored
61
Jenkinsfile
vendored
@@ -1,7 +1,7 @@
|
||||
pipeline {
|
||||
agent {
|
||||
kubernetes {
|
||||
// Definiert den Pod mit dem .NET 8 SDK Image
|
||||
// Definieren des Pod mit 3 Containern als Build Agent, Trivy und Kaniko
|
||||
yaml '''
|
||||
apiVersion: v1
|
||||
kind: Pod
|
||||
@@ -26,15 +26,16 @@ pipeline {
|
||||
}
|
||||
|
||||
options {
|
||||
// Log-Rotation: Bewahre nur die letzten 10 Builds auf
|
||||
// und lösche Berichte/Artefakte von Builds, die älter als 7 Tage sind.
|
||||
// Aktivieren von Log Rotation:
|
||||
// *) Letzten 10 Builds werden aufbewahrt
|
||||
// ** Builds, die älter als 7 Tage sind, werden gelöscht
|
||||
buildDiscarder(logRotator(numToKeepStr: '10', artifactNumToKeepStr: '10', daysToKeepStr: '7'))
|
||||
}
|
||||
|
||||
stages {
|
||||
// Auschecken der Sourcen zum App Projekt
|
||||
stage('Checkout Source') {
|
||||
steps {
|
||||
// Ersetze 'dein-user' und 'dein-repo' durch die Namen aus Gitea
|
||||
git url: 'http://130.61.26.230:30080/dev-master/secdevops-csharp-app.git',
|
||||
branch: 'master'
|
||||
}
|
||||
@@ -42,27 +43,29 @@ pipeline {
|
||||
|
||||
stage('Security: Trivy Scan') {
|
||||
steps {
|
||||
// Wiederherstellen der project.assets.json in obj/ für Trivy zum finden der transtiven Abhängigkeiten
|
||||
// Ausführen des 'dotnet restore' für den nachfolgenden Trivy Scan, der diese wiederhergestellte Dateien/NuGet Pakete und Abhängigkeiten scanned
|
||||
// Generiert automatisch das obj/ mit der project.assets.json
|
||||
// Alle Container eines Pods teilen sich das Jenkins Arbeitsverzeichnis
|
||||
container('dotnet8') {
|
||||
sh 'dotnet restore'
|
||||
}
|
||||
|
||||
// Ausführen des Trivy Scans
|
||||
//
|
||||
// Wichtig: trivy ersetzt -> dotnet list package --vulnerable --include-transitive
|
||||
container('trivy') {
|
||||
// Wir erstellen ein Verzeichnis für den Report
|
||||
// Erzeugen des Directory zum Speichern des Reports
|
||||
sh 'mkdir -p reports'
|
||||
|
||||
// Wichtig: trivy ersetzt -> dotnet list package --vulnerable --include-transitive
|
||||
|
||||
// Der Befehl erzeugt die HTML-Datei
|
||||
// --format template: Nutzt ein Layout
|
||||
// --template "@/contrib/html.tpl": Das Standard-Trivy-Layout
|
||||
// Scannt das Dateisystem auf Schwachstellen (NuGet) und Secrets
|
||||
// --exit-code 1 lässt die Pipeline bei kritischen Fehlern abbrechen
|
||||
sh 'trivy fs --scanners vuln,misconfig,secret,license --exit-code 1 --severity HIGH,CRITICAL --format template --template "@/contrib/html.tpl" -o reports/trivy-fs-report.html .'
|
||||
// Ausführen des Scans hinsichtlich Vulnerabilities, Miskonfigurationen, Secrets und Licences im Jenkins Arbeitsverzeichnis
|
||||
// Abbruch bei bei kritischen Fehlern (--exit-code 1 --severity HIGH,CRITICAL)
|
||||
sh 'trivy fs --scanners vuln,misconfig,secret,license --exit-code 1 --severity HIGH,CRITICAL --format template --template "html" -o reports/trivy-fs-report.html .'
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Kompilieren der Anwendung (DLLs werden erzeugt)
|
||||
// Schritt muss gar nicht durchgeführt werden, da kaniko das Image erzeugt
|
||||
stage('Build with .NET 8') {
|
||||
steps {
|
||||
// Führt den Build-Befehl im spezialisierten Container aus
|
||||
@@ -87,7 +90,7 @@ pipeline {
|
||||
stage('Set Build Name') {
|
||||
steps {
|
||||
script {
|
||||
// Setzt den Namen des aktuellen Laufs auf die Version + Build-Nummer
|
||||
// Setzen des Namen des aktuellen Laufs auf die Version + Build-Nummer
|
||||
currentBuild.displayName = "v1.0.0-build-${env.BUILD_NUMBER}"
|
||||
}
|
||||
}
|
||||
@@ -100,12 +103,18 @@ pipeline {
|
||||
|
||||
steps {
|
||||
container('kaniko') {
|
||||
// Nutze die ID, die du in Jenkins für den Token vergeben hast
|
||||
// Stellt die Informationen aus dem Token in Form von Umgebungsvariablen der Jenkins Pipeline zur Verfügung
|
||||
// Nachfolgend werden diese Credentials im JSON Format in config.json geschrieben
|
||||
// Vorgehen ist zwar nicht extrem sicher, aber die Lebenszeit im Container ist kurz, dass diese base64 kodierten Daten zurückverwandelt werden könnten
|
||||
|
||||
// Erzeugen des Directory zum Speichern des Reports, falls das bei einem vorigen Schritt nicht durchgeführt wurde
|
||||
sh 'mkdir -p reports'
|
||||
|
||||
withCredentials([usernamePassword(credentialsId: 'gitea-registry-token',
|
||||
usernameVariable: 'GITEA_USER',
|
||||
passwordVariable: 'GITEA_TOKEN')]) {
|
||||
sh '''
|
||||
# WORKAROUND: Dem Container beibringen, wer git.example.com ist
|
||||
# WORKAROUND: Dem Container beibringen, wer git.example.com ist, ansonsten funktioniert das Übertragen des Images an Git nicht!!!
|
||||
echo "130.61.26.230 git.example.com" >> /etc/hosts
|
||||
|
||||
# Erstellt die Docker-Konfiguration für Kaniko
|
||||
@@ -126,26 +135,27 @@ pipeline {
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
stage('Security: Trivy Image Scan') {
|
||||
when {
|
||||
branch 'master'
|
||||
}
|
||||
steps {
|
||||
|
||||
// Trivy Scan wird auf das Image im Git Repository angewendet. Das Image wird heruntergeladen.
|
||||
container('trivy') {
|
||||
// 1. Scan ausführen und als HTML-Report speichern (Achte auf den neuen Dateinamen)
|
||||
sh '''
|
||||
trivy image --insecure \
|
||||
--severity HIGH,CRITICAL \
|
||||
--format template \
|
||||
--template "@/contrib/html.tpl" \
|
||||
--template "html" \
|
||||
--exit-code 1 \
|
||||
-o reports/trivy-image-report.html \
|
||||
130.61.26.230:30080/dev-master/secdevops-csharp-app:latest
|
||||
'''
|
||||
|
||||
// 2. Den Scan ein zweites Mal kurz ohne Report ausführen, damit die Pipeline bei Lücken blockiert
|
||||
sh 'trivy image --insecure --exit-code 1 --severity HIGH,CRITICAL 130.61.26.230:30080/dev-master/secdevops-csharp-app:latest'
|
||||
// Den Scan ein zweites Mal kurz ohne Report ausführen, damit die Pipeline bei Lücken blockiert
|
||||
// sh 'trivy image --insecure --exit-code 1 --severity HIGH,CRITICAL 130.61.26.230:30080/dev-master/secdevops-csharp-app:latest'
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -158,11 +168,10 @@ pipeline {
|
||||
}
|
||||
}
|
||||
always {
|
||||
// Sammelt die Testergebnisse ein (die wir im Test-Schritt erzeugen)
|
||||
// Das **/ bedeutet: Suche in allen Unterordnern nach .xml Dateien
|
||||
// Suchen und Einelen von etwaigen Testreports von JUnit. Keine Vorhanden? -auch ok
|
||||
junit testResults: '**/*.xml', allowEmptyResults: true
|
||||
|
||||
// Dieser Schritt macht den Report im Jenkins-Menü links sichtbar
|
||||
// Verwenden des HTML Publisher Modules zum Schreiben der gefundenen Testreports in das Build Menu und speichert den HTML Bericht dann historisch ab (keepAll)
|
||||
publishHTML([
|
||||
allowMissing: false,
|
||||
alwaysLinkToLastBuild: true,
|
||||
@@ -172,7 +181,7 @@ pipeline {
|
||||
reportName: 'Trivy Security Report'
|
||||
])
|
||||
|
||||
// Meldet den Status zurück, wenn das Gitea-Plugin korrekt konfiguriert ist
|
||||
// Schreiben des Build Status in das Build Log
|
||||
echo "Pipeline beendet: ${currentBuild.result}"
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user