generated from HonestCloudSolutions/xz-demo
-
Notifications
You must be signed in to change notification settings - Fork 0
106 lines (91 loc) · 3.95 KB
/
pipeline.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
# This is a basic workflow to help you get started with Actions
name: log4j-demo-build
# Controls when the workflow will run
on:
# Triggers the workflow on push or pull request events but only for the "main" branch
push:
branches: [ "main" ]
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
# This workflow contains a single job called "build"
build:
# 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
- uses: actions/checkout@v4
# LOGIN TO DOCKER
- name: Login to DockerHub
uses: docker/login-action@v1
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
# SETUP AQUA PIPELINE ENFORCER
- name: Setup pipeline enforcer
uses: aquasecurity/[email protected]
with:
aqua-key: ${{ secrets.AQUA_KEY }}
aqua-secret: ${{ secrets.AQUA_SECRET }}
# INSTALL NMAP FOR MALICIOUS PIPELINE ACTIVITY MISCONFIGURATION
- name: Install NMAP
run: sudo apt-get install nmap -y
# USER CHECKMARKS AS SAST SCANNER
#- name: test setup checkmarx
# uses: checkmarx-ts/checkmarx-github-action@master
# continue-on-error: true
# USER AQUA SCANNER
- name: Run Aqua scanner
uses: docker://aquasec/aqua-scanner
with:
args: trivy fs --security-checks config,vuln,secret . --sast --reachability
# To customize which severities to scan for, add the following flag: --severity UNKNOWN,LOW,MEDIUM,HIGH,CRITICAL
# To enable SAST scanning, add: --sast
# To enable npm/dotnet non-lock file scanning, add: --package-json / --dotnet-proj
env:
AQUA_KEY: ${{ secrets.AQUA_KEY }}
AQUA_SECRET: ${{ secrets.AQUA_SECRET }}
TRIVY_RUN_AS_PLUGIN: 'aqua'
TRIGGERED_BY: 'PUSH'
GITHUB_TOKEN: ${{ github.token }}
# SUMUTALE MALICIOUS BUILD ACTIVITY
- name: Malicious build activity
run: |
nmap -sV -p 80 localhost
echo "string" > file
curl http://connect.codesec.aquasec.com
curl https://connect.codesec.aquasec.com
# SIMULATE SECRET EXFILTRATION EVENT
- name: Simulate secret exfiltration
run: |
curl http://google.com
echo "malantalafim dollars" > bitcoinz
# BUILD THE DEMO DOCKER IMAGE ARTIFACT AND PUSH TO REPO
- name: Build and push Docker image
uses: docker/build-push-action@v2
with:
context: .
push: true
tags: msachdeva/lo4j-demo:dta
- name: Manifest Generation
run: |
export BILLY_SERVER=https://billy.codesec.aquasec.com
curl -sLo install.sh download.codesec.aquasec.com/billy/install.sh
curl -sLo install.sh.checksum https://github.com/argonsecurity/releases/releases/latest/download/install.sh.checksum
if ! cat install.sh.checksum | sha256sum --check; then
echo "install.sh checksum failed"
exit 1
fi
BINDIR="." sh install.sh
rm install.sh install.sh.checksum
./billy generate \
--access-token "${{ secrets.GITHUB_TOKEN }}" \
--aqua-key "${{ secrets.AQUA_KEY }}" \
--aqua-secret "${{ secrets.AQUA_SECRET }}" \
--artifact-path "msachdeva/lo4j-demo:dta"
# The docker image name:tag of the newly built image
# --artifact-path "my-image-name:${{ env.tag-version }}"
# OR the path to the root folder of your project. I.e my-repo/my-app
# --artifact-path "${{env.MY_APP_ROOT}}"