|
| 1 | +--- |
| 2 | +title: "Trivy SBOM" |
| 3 | +category: "scanner" |
| 4 | +type: "Container" |
| 5 | +state: "released" |
| 6 | +appVersion: "0.45.0" |
| 7 | +usecase: "Container Dependency Scanner" |
| 8 | +--- |
| 9 | + |
| 10 | +<!-- |
| 11 | +SPDX-FileCopyrightText: the secureCodeBox authors |
| 12 | +
|
| 13 | +SPDX-License-Identifier: Apache-2.0 |
| 14 | +--> |
| 15 | +<!-- |
| 16 | +.: IMPORTANT! :. |
| 17 | +-------------------------- |
| 18 | +This file is generated automatically with `helm-docs` based on the following template files: |
| 19 | +- ./.helm-docs/templates.gotmpl (general template data for all charts) |
| 20 | +- ./chart-folder/.helm-docs.gotmpl (chart specific template data) |
| 21 | +
|
| 22 | +Please be aware of that and apply your changes only within those template files instead of this file. |
| 23 | +Otherwise your changes will be reverted/overwritten automatically due to the build process `./.github/workflows/helm-docs.yaml` |
| 24 | +-------------------------- |
| 25 | +--> |
| 26 | + |
| 27 | +<p align="center"> |
| 28 | + <a href="https://opensource.org/licenses/Apache-2.0"><img alt="License Apache-2.0" src="https://img.shields.io/badge/License-Apache%202.0-blue.svg"/></a> |
| 29 | + <a href="https://github.com/secureCodeBox/secureCodeBox/releases/latest"><img alt="GitHub release (latest SemVer)" src="https://img.shields.io/github/v/release/secureCodeBox/secureCodeBox?sort=semver"/></a> |
| 30 | + <a href="https://owasp.org/www-project-securecodebox/"><img alt="OWASP Lab Project" src="https://img.shields.io/badge/OWASP-Lab%20Project-yellow"/></a> |
| 31 | + <a href="https://artifacthub.io/packages/search?repo=securecodebox"><img alt="Artifact HUB" src="https://img.shields.io/endpoint?url=https://artifacthub.io/badge/repository/securecodebox"/></a> |
| 32 | + <a href="https://github.com/secureCodeBox/secureCodeBox/"><img alt="GitHub Repo stars" src="https://img.shields.io/github/stars/secureCodeBox/secureCodeBox?logo=GitHub"/></a> |
| 33 | + <a href="https://twitter.com/securecodebox"><img alt="Twitter Follower" src="https://img.shields.io/twitter/follow/securecodebox?style=flat&color=blue&logo=twitter"/></a> |
| 34 | +</p> |
| 35 | + |
| 36 | +## What is Trivy SBOM? |
| 37 | + |
| 38 | +`Trivy` (`tri` pronounced like **tri**gger, `vy` pronounced like en**vy**) is a simple and comprehensive vulnerability scanner for containers and other artifacts. |
| 39 | +A software vulnerability is a glitch, flaw, or weakness present in the software or in an Operating System. |
| 40 | +`Trivy` detects vulnerabilities of OS packages (Alpine, RHEL, CentOS, etc.) and application dependencies (Bundler, Composer, npm, yarn, etc.). |
| 41 | +`Trivy` is easy to use. Just install the binary, and you're ready to scan. All you need to do for scanning is to specify a target such as an image name of the container. |
| 42 | + |
| 43 | +To learn more about the Trivy scanner itself visit [Trivy's GitHub Repository](https://github.com/aquasecurity/trivy). |
| 44 | + |
| 45 | +This chart uses Trivy's SBOM support to generate Software Bills of Material in CycloneDX format for container images. |
| 46 | + |
| 47 | +## Deployment |
| 48 | +The trivy-sbom chart can be deployed via helm: |
| 49 | + |
| 50 | +```bash |
| 51 | +# Install HelmChart (use -n to configure another namespace) |
| 52 | +helm upgrade --install trivy-sbom secureCodeBox/trivy-sbom |
| 53 | +``` |
| 54 | + |
| 55 | +## Scanner Configuration |
| 56 | + |
| 57 | +The following SBOM generation configuration example is based on the [Trivy Documentation](https://aquasecurity.github.io/trivy/), please take a look at the original documentation for more configuration examples. |
| 58 | + |
| 59 | +Currently we support the following scanType, corresponding to the trivy scanning modes: |
| 60 | +- scanType: "trivy-sbom-image" |
| 61 | + - parameters: `[YOUR_IMAGE_NAME]` |
| 62 | + |
| 63 | +Simply specify an image name (and a tag) when you use the scanType `trivy-sbom-image`. |
| 64 | +A complete example is listed below in our [example docs section](https://www.securecodebox.io/docs/scanners/trivy/#examples). |
| 65 | + |
| 66 | +## Requirements |
| 67 | + |
| 68 | +Kubernetes: `>=v1.11.0-0` |
| 69 | + |
| 70 | +## Values |
| 71 | + |
| 72 | +| Key | Type | Default | Description | |
| 73 | +|-----|------|---------|-------------| |
| 74 | +| cascadingRules.enabled | bool | `false` | Enables or disables the installation of the default cascading rules for this scanner | |
| 75 | +| imagePullSecrets | list | `[]` | Define imagePullSecrets when a private registry is used (see: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/) | |
| 76 | +| parser.affinity | object | `{}` | Optional affinity settings that control how the parser job is scheduled (see: https://kubernetes.io/docs/tasks/configure-pod-container/assign-pods-nodes-using-node-affinity/) | |
| 77 | +| parser.env | list | `[]` | Optional environment variables mapped into each parseJob (see: https://kubernetes.io/docs/tasks/inject-data-application/define-environment-variable-container/) | |
| 78 | +| parser.image.pullPolicy | string | `"IfNotPresent"` | Image pull policy. One of Always, Never, IfNotPresent. Defaults to Always if :latest tag is specified, or IfNotPresent otherwise. More info: https://kubernetes.io/docs/concepts/containers/images#updating-images | |
| 79 | +| parser.image.repository | string | `"docker.io/securecodebox/parser-cyclonedx"` | Parser image repository | |
| 80 | +| parser.image.tag | string | defaults to the charts version | Parser image tag | |
| 81 | +| parser.resources | object | { requests: { cpu: "200m", memory: "100Mi" }, limits: { cpu: "400m", memory: "200Mi" } } | Optional resources lets you control resource limits and requests for the parser container. See https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ | |
| 82 | +| parser.scopeLimiterAliases | object | `{}` | Optional finding aliases to be used in the scopeLimiter. | |
| 83 | +| parser.tolerations | list | `[]` | Optional tolerations settings that control how the parser job is scheduled (see: https://kubernetes.io/docs/concepts/scheduling-eviction/taint-and-toleration/) | |
| 84 | +| parser.ttlSecondsAfterFinished | string | `nil` | seconds after which the Kubernetes job for the parser will be deleted. Requires the Kubernetes TTLAfterFinished controller: https://kubernetes.io/docs/concepts/workloads/controllers/ttlafterfinished/ | |
| 85 | +| scanner.activeDeadlineSeconds | string | `nil` | There are situations where you want to fail a scan Job after some amount of time. To do so, set activeDeadlineSeconds to define an active deadline (in seconds) when considering a scan Job as failed. (see: https://kubernetes.io/docs/concepts/workloads/controllers/job/#job-termination-and-cleanup) | |
| 86 | +| scanner.affinity | object | `{}` | Optional affinity settings that control how the scanner job is scheduled (see: https://kubernetes.io/docs/tasks/configure-pod-container/assign-pods-nodes-using-node-affinity/) | |
| 87 | +| scanner.backoffLimit | int | 3 | There are situations where you want to fail a scan Job after some amount of retries due to a logical error in configuration etc. To do so, set backoffLimit to specify the number of retries before considering a scan Job as failed. (see: https://kubernetes.io/docs/concepts/workloads/controllers/job/#pod-backoff-failure-policy) | |
| 88 | +| scanner.env | list | `[]` | Optional environment variables mapped into each scanJob (see: https://kubernetes.io/docs/tasks/inject-data-application/define-environment-variable-container/) | |
| 89 | +| scanner.extraContainers | list | `[]` | Optional additional Containers started with each scanJob (see: https://kubernetes.io/docs/concepts/workloads/pods/init-containers/) | |
| 90 | +| scanner.extraVolumeMounts | list | `[]` | Optional VolumeMounts mapped into each scanJob (see: https://kubernetes.io/docs/concepts/storage/volumes/) | |
| 91 | +| scanner.extraVolumes | list | `[]` | Optional Volumes mapped into each scanJob (see: https://kubernetes.io/docs/concepts/storage/volumes/) | |
| 92 | +| scanner.image.pullPolicy | string | `"IfNotPresent"` | Image pull policy. One of Always, Never, IfNotPresent. Defaults to Always if :latest tag is specified, or IfNotPresent otherwise. More info: https://kubernetes.io/docs/concepts/containers/images#updating-images | |
| 93 | +| scanner.image.repository | string | `"docker.io/aquasec/trivy"` | Container Image to run the scan | |
| 94 | +| scanner.image.tag | string | `nil` | defaults to the charts appVersion | |
| 95 | +| scanner.nameAppend | string | `nil` | append a string to the default scantype name. | |
| 96 | +| scanner.podSecurityContext | object | `{}` | Optional securityContext set on scanner pod (see: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/) | |
| 97 | +| scanner.resources | object | `{}` | CPU/memory resource requests/limits (see: https://kubernetes.io/docs/tasks/configure-pod-container/assign-memory-resource/, https://kubernetes.io/docs/tasks/configure-pod-container/assign-cpu-resource/) | |
| 98 | +| scanner.securityContext | object | `{"allowPrivilegeEscalation":false,"capabilities":{"drop":["all"]},"privileged":false,"readOnlyRootFilesystem":false,"runAsNonRoot":false}` | Optional securityContext set on scanner container (see: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/) | |
| 99 | +| scanner.securityContext.allowPrivilegeEscalation | bool | `false` | Ensure that users privileges cannot be escalated | |
| 100 | +| scanner.securityContext.capabilities.drop[0] | string | `"all"` | This drops all linux privileges from the container. | |
| 101 | +| scanner.securityContext.privileged | bool | `false` | Ensures that the scanner container is not run in privileged mode | |
| 102 | +| scanner.securityContext.readOnlyRootFilesystem | bool | `false` | Prevents write access to the containers file system | |
| 103 | +| scanner.securityContext.runAsNonRoot | bool | `false` | Enforces that the scanner image is run as a non root user | |
| 104 | +| scanner.suspend | bool | `false` | if set to true the scan job will be suspended after creation. You can then resume the job using `kubectl resume <jobname>` or using a job scheduler like kueue | |
| 105 | +| scanner.tolerations | list | `[]` | Optional tolerations settings that control how the scanner job is scheduled (see: https://kubernetes.io/docs/concepts/scheduling-eviction/taint-and-toleration/) | |
| 106 | +| scanner.ttlSecondsAfterFinished | string | `nil` | seconds after which the Kubernetes job for the scanner will be deleted. Requires the Kubernetes TTLAfterFinished controller: https://kubernetes.io/docs/concepts/workloads/controllers/ttlafterfinished/ | |
| 107 | + |
| 108 | +## License |
| 109 | +[](https://opensource.org/licenses/Apache-2.0) |
| 110 | + |
| 111 | +Code of secureCodeBox is licensed under the [Apache License 2.0][scb-license]. |
| 112 | + |
| 113 | +[scb-owasp]: https://www.owasp.org/index.php/OWASP_secureCodeBox |
| 114 | +[scb-docs]: https://www.securecodebox.io/ |
| 115 | +[scb-site]: https://www.securecodebox.io/ |
| 116 | +[scb-github]: https://github.com/secureCodeBox/ |
| 117 | +[scb-twitter]: https://twitter.com/secureCodeBox |
| 118 | +[scb-slack]: https://join.slack.com/t/securecodebox/shared_invite/enQtNDU3MTUyOTM0NTMwLTBjOWRjNjVkNGEyMjQ0ZGMyNDdlYTQxYWQ4MzNiNGY3MDMxNThkZjJmMzY2NDRhMTk3ZWM3OWFkYmY1YzUxNTU |
| 119 | +[scb-license]: https://github.com/secureCodeBox/secureCodeBox/blob/master/LICENSE |
| 120 | + |
0 commit comments