-
Notifications
You must be signed in to change notification settings - Fork 0
116 lines (100 loc) · 3.73 KB
/
build-ci.yml
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
# This is the build workflow to help maintain the project
name: Build CI
# Controls when the workflow will run
on:
# Triggers the workflow on push or pull request events but only for the "master" branch
push:
branches: ["main", "dev"]
pull_request:
branches: ["main", "dev"]
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# These permissions are needed to interact with GitHub's OIDC Token endpoint.
permissions:
id-token: write # This is required for requesting the JWT
contents: read # This is required for actions/checkout
pull-requests: read
security-events: write
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
iac-scan:
# The type of runner that the job will run on
runs-on: ubuntu-latest
# Steps represent a sequence of tasks that will be executed as part of the job
steps:
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- name: Git Checkout
uses: actions/[email protected]
- name: Get changed files
id: changed-files
uses: tj-actions/[email protected]
with:
files_ignore: |
.github/**
.dockerignore
.env
.env.example
.gitattributes
.gitignore
config.json
config.json.example
**.md
LICENSE
- name: List all changed files
env:
ALL_CHANGED_FILES: ${{ steps.changed-files.outputs.all_changed_files }}
run: |
for file in ${ALL_CHANGED_FILES}; do
echo "$file was changed"
done
- name: Set up Docker Buildx
if: steps.changed-files.outputs.any_changed == 'true'
uses: docker/setup-buildx-action@v3
- name: Build Docker image
if: steps.changed-files.outputs.any_changed == 'true'
uses: docker/[email protected]
with:
context: .
file: Dockerfile
push: false
# sbom: true
tags: georgedavisibexlabs/publish-sarif-to-jira:build
- name: Run Trivy in GitHub SBOM mode and submit results to Dependency Graph
if: steps.changed-files.outputs.any_changed == 'true'
uses: aquasecurity/[email protected]
with:
scan-type: 'fs'
format: 'github'
output: 'dependency-results.sbom.json'
image-ref: '.'
github-pat: ${{ secrets.GITHUB_TOKEN }}
- name: Upload trivy SBOM as a Github artifact
if: steps.changed-files.outputs.any_changed == 'true'
uses: actions/[email protected]
with:
name: trivy-sbom-report
path: trivy-dependency-results.sbom.json
retention-days: 30
- name: List Docker Containers
if: steps.changed-files.outputs.any_changed == 'true'
run: 'docker ps -a'
- name: List Docker Images
if: steps.changed-files.outputs.any_changed == 'true'
run: 'docker images'
# - name: Run Trivy Image scanner
# uses: aquasecurity/[email protected]
# with:
# scan-type: 'image'
# image-ref: 'georgedavisibexlabs/publish-sarif-to-jira'
# limit-severities-for-sarif: true
# trivy-config: .github/config/trivy-sarif.yaml
# - name: Upload Trivy Image scan results
# uses: actions/[email protected]
# with:
# name: trivy-image-scan-results
# path: trivy-image-scan-results.sarif
# retention-days: 30
# - name: Upload Trivy scan results to GitHub Security tab
# uses: github/codeql-action/upload-sarif@v3
# with:
# sarif_file: 'trivy-image-scan-results.sarif'