https://github.com/avinashupadhya99/kubescape-action
GitHub action to run Kubescape scans
https://github.com/avinashupadhya99/kubescape-action
github-actions kubernetes-security
Last synced: 4 months ago
JSON representation
GitHub action to run Kubescape scans
- Host: GitHub
- URL: https://github.com/avinashupadhya99/kubescape-action
- Owner: avinashupadhya99
- Created: 2022-02-19T08:29:15.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2022-08-24T03:38:49.000Z (about 3 years ago)
- Last Synced: 2025-06-10T17:04:49.043Z (5 months ago)
- Topics: github-actions, kubernetes-security
- Language: Shell
- Homepage:
- Size: 10.7 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Kubescape action
Run security scans on your Kubernetes manifests and Helm charts as a part of your CI using the Kubescape action. Kubescape scans K8s clusters, YAML files, and HELM charts, detecting misconfigurations according to multiple frameworks (such as the [NSA-CISA](https://www.armosec.io/blog/kubernetes-hardening-guidance-summary-by-armo) , [MITRE ATT&CK®](https://www.microsoft.com/security/blog/2021/03/23/secure-containerized-environments-with-updated-threat-matrix-for-kubernetes/)), software vulnerabilities.
## Usage
Add the following step to your workflow configuration:
```yaml
steps:
- uses: actions/checkout@v2
- uses: avinashupadhya99/kubescape-action@main
with:
files: kubernetes/*.yaml
```## Inputs
| Name | Description | Required |
| --- | --- | ---|
| files | The YAML files/Helm charts to scan for misconfigurations. The files need to be provided with the complete path from the root of the repository. | Yes |
| threshold | Failure threshold is the percent above which the command fails and returns exit code 1 (default 0 i.e, action fails if any control fails) | No (default 0) |
| framework | The security framework(s) to scan the files against. Multiple frameworks can be specified separated by a comma with no spaces. Example - `nsa,devopsbest`. Run `kubescape list frameworks` with the [Kubescape CLI](https://hub.armo.cloud/docs/installing-kubescape) to get a list of all frameworks. Either frameworks have to be specified or controls. | No |
| control | The security control(s) to scan the files against. Multiple controls can be specified separated by a comma with no spaces. Example - `Configured liveness probe,Pods in default namespace`. Run `kubescape list controls` with the [Kubescape CLI](https://hub.armo.cloud/docs/installing-kubescape) to get a list of all controls. The complete control name can be specified or the ID such as `C-0001` can be specified. Either controls have to be specified or frameworks. | No |
| args | Additional arguments to the Kubescape CLI. The following arguments are supported -
- ` -f, --format` - Output format. Supported formats: "pretty-printer"/"json"/"junit"/"prometheus" (default "pretty-printer")
- `-o, --output` - Output file. Print output to file and not stdout
- `--exceptions` - Provide path to an [exception](https://hub.armo.cloud/docs/exceptions) object.
- ` -s, --silent` - Silent progress messages
- `--verbose` - Display all of the input resources and not only failed resources
- `--logger` - Logger level. Supported: debug/info/success/warning/error/fatal (default "info")
## Examples
- Standard
```yaml
name: Scan YAML files with Kubescape
on: push
jobs:
kubescape:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- uses: avinashupadhya99/kubescape-action@main
with:
files: "kubernetes-prod/*.yaml"
```
- With arguments
```yaml
name: Scan YAML files using Kubescape with additional arguments
on: push
jobs:
kubescape:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- uses: avinashupadhya99/kubescape-action@main
with:
args: "--fail-threshold 90"
files: "kubernetes-prod/*.yaml"
```
- Specifying frameworks
```yaml
name: Scan YAML files using Kubescape and against specific frameworks
on: push
jobs:
kubescape:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- uses: avinashupadhya99/kubescape-action@main
with:
files: "kubernetes-prod/*.yaml"
framework: |
nsa,devopsbest
```
- Specific controls
```yaml
name: Scan YAML files using Kubescape and for specific controls
on: push
jobs:
kubescape:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- uses: avinashupadhya99/kubescape-action@main
with:
files: "kubernetes-prod/*.yaml"
control: |
Configured liveness probe,Pods in default namespace,Bash/cmd inside container
```
- Store the results in a file as an artifacts
```yaml
name: Scan YAML files with Kubescape and store results as an artifact
on: push
jobs:
kubescape:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- uses: avinashupadhya99/kubescape-action@main
with:
args: "--format junit --output results.xml"
files: "kubernetes-prod/*.yaml"
framework: nsa
- name: Archive kubescape scan results
uses: actions/upload-artifact@v2
with:
name: kubescape-scan-report
path: results.xml
```
## License
[//]: TODO