-
Notifications
You must be signed in to change notification settings - Fork 1
/
Jenkinsfile
84 lines (84 loc) · 2.58 KB
/
Jenkinsfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
pipeline {
agent any
tools {
jdk 'jdk17'
nodejs 'node20'
}
environment {
SCANNER_HOME = tool 'sonar-scanner'
NVD_API_KEY = credentials('nvd-key') // Add your credential ID here
}
stages {
stage('Clean Workspace') {
steps {
cleanWs()
}
}
stage('Checkout from Git') {
steps {
git branch: 'main', url: 'https://github.com/dmcomp07/netflix-clone.git'
}
}
stage('SonarQube Analysis') {
steps {
withSonarQubeEnv('sonar-server') {
sh '''
$SCANNER_HOME/bin/sonar-scanner \
-Dsonar.projectName=Netflix \
-Dsonar.projectKey=Netflix
'''
}
}
}
stage('Install Dependencies') {
steps {
sh 'npm install'
}
}
stage('OWASP FS Scan') {
steps {
dependencyCheck additionalArguments: '--scan ./ --disableYarnAudit --disableNodeAudit --nvdApiKey $NVD_API_KEY', odcInstallation: 'DP-Check'
dependencyCheckPublisher pattern: '**/dependency-check-report.xml'
}
}
stage('Trivy FS Scan') {
steps {
sh 'trivy fs . > trivyfs.txt'
}
}
stage('Docker Build & Push') {
steps {
script {
withDockerRegistry(credentialsId: 'docker', toolName: 'docker') {
sh '''
docker build --build-arg TMDB_V3_API_KEY=e3edc982bbb9895c87ca1912936c5781 -t netflix .
docker tag netflix dmcomp07/netflix:latest
docker push dmcomp07/netflix:latest
'''
}
}
}
}
stage('Trivy Image Scan') {
steps {
sh 'trivy image dmcomp07/netflix:latest > trivyimage.txt'
}
}
stage('Deploy to Container') {
steps {
sh 'docker run -d -p 8081:80 dmcomp07/netflix:latest'
}
}
stage('Quality Gate') {
parallel {
stage('SonarQube Quality Gate') {
steps {
script {
waitForQualityGate abortPipeline: false, credentialsId: 'sonar-token'
}
}
}
}
}
}
}