{"date":"2025-01-06T19:58:14Z","repo":{"name":"github.com/nginxinc/nginx-gateway-fabric","commit":"774a7c27d3e22fe110370a8cabfc0b9dda325bc2"},"scorecard":{"version":"v5.0.0","commit":"ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4"},"score":8.6,"checks":[{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#binary-artifacts"}},{"name":"Branch-Protection","score":5,"reason":"branch protection is not maximal on development and all release branches","details":["Info: 'allow deletion' disabled on branch 'main'","Info: 'allow deletion' disabled on branch 'release-1.5'","Info: 'allow deletion' disabled on branch 'release-1.4'","Info: 'allow deletion' disabled on branch 'release-1.3'","Info: 'allow deletion' disabled on branch 'release-1.2'","Info: 'allow deletion' disabled on branch 'release-1.1'","Info: 'allow deletion' disabled on branch 'release-1.0'","Info: 'allow deletion' disabled on branch 'release-0.6'","Info: 'allow deletion' disabled on branch 'release-0.5'","Info: 'allow deletion' disabled on branch 'release-0.4'","Info: 'allow deletion' disabled on branch 'release-0.3'","Info: 'allow deletion' disabled on branch 'release-0.2'","Info: 'allow deletion' disabled on branch 'release-0.1'","Info: 'force pushes' disabled on branch 'main'","Info: 'force pushes' disabled on branch 'release-1.5'","Info: 'force pushes' disabled on branch 'release-1.4'","Info: 'force pushes' disabled on branch 'release-1.3'","Info: 'force pushes' disabled on branch 'release-1.2'","Info: 'force pushes' disabled on branch 'release-1.1'","Info: 'force pushes' disabled on branch 'release-1.0'","Info: 'force pushes' disabled on branch 'release-0.6'","Info: 'force pushes' disabled on branch 'release-0.5'","Info: 'force pushes' disabled on branch 'release-0.4'","Info: 'force pushes' disabled on branch 'release-0.3'","Info: 'force pushes' disabled on branch 'release-0.2'","Info: 'force pushes' disabled on branch 'release-0.1'","Warn: 'branch protection settings apply to administrators' is disable on branch 'main'","Warn: 'branch protection settings apply to administrators' is disable on branch 'release-1.5'","Warn: 'branch protection settings apply to administrators' is disable on branch 'release-1.4'","Warn: 'branch protection settings apply to administrators' is disable on branch 'release-1.3'","Warn: 'branch protection settings apply to administrators' is disable on branch 'release-1.2'","Warn: 'branch protection settings apply to administrators' is disable on branch 'release-1.1'","Warn: 'branch protection settings apply to administrators' is disable on branch 'release-1.0'","Warn: 'branch protection settings apply to administrators' is disable on branch 'release-0.6'","Warn: 'branch protection settings apply to administrators' is disable on branch 'release-0.5'","Warn: 'branch protection settings apply to administrators' is disable on branch 'release-0.4'","Warn: 'branch protection settings apply to administrators' is disable on branch 'release-0.3'","Warn: 'branch protection settings apply to administrators' is disable on branch 'release-0.2'","Warn: 'branch protection settings apply to administrators' is disable on branch 'release-0.1'","Warn: 'stale review dismissal' is disable on branch 'main'","Warn: 'stale review dismissal' is disable on branch 'release-1.5'","Warn: 'stale review dismissal' is disable on branch 'release-1.4'","Warn: 'stale review dismissal' is disable on branch 'release-1.3'","Warn: 'stale review dismissal' is disable on branch 'release-1.2'","Warn: 'stale review dismissal' is disable on branch 'release-1.1'","Warn: 'stale review dismissal' is disable on branch 'release-1.0'","Warn: 'stale review dismissal' is disable on branch 'release-0.6'","Warn: 'stale review dismissal' is disable on branch 'release-0.5'","Warn: 'stale review dismissal' is disable on branch 'release-0.4'","Warn: 'stale review dismissal' is disable on branch 'release-0.3'","Warn: 'stale review dismissal' is disable on branch 'release-0.2'","Warn: 'stale review dismissal' is disable on branch 'release-0.1'","Info: required approving review count is 2 on branch 'main'","Info: required approving review count is 2 on branch 'release-1.5'","Info: required approving review count is 2 on branch 'release-1.4'","Info: required approving review count is 2 on branch 'release-1.3'","Info: required approving review count is 2 on branch 'release-1.2'","Info: required approving review count is 2 on branch 'release-1.1'","Info: required approving review count is 2 on branch 'release-1.0'","Info: required approving review count is 2 on branch 'release-0.6'","Info: required approving review count is 2 on branch 'release-0.5'","Info: required approving review count is 2 on branch 'release-0.4'","Info: required approving review count is 2 on branch 'release-0.3'","Info: required approving review count is 2 on branch 'release-0.2'","Info: required approving review count is 2 on branch 'release-0.1'","Info: codeowner review is required on branch 'main'","Info: codeowner review is required on branch 'release-1.5'","Info: codeowner review is required on branch 'release-1.4'","Info: codeowner review is required on branch 'release-1.3'","Info: codeowner review is required on branch 'release-1.2'","Info: codeowner review is required on branch 'release-1.1'","Info: codeowner review is required on branch 'release-1.0'","Info: codeowner review is required on branch 'release-0.6'","Info: codeowner review is required on branch 'release-0.5'","Info: codeowner review is required on branch 'release-0.4'","Info: codeowner review is required on branch 'release-0.3'","Info: codeowner review is required on branch 'release-0.2'","Info: codeowner review is required on branch 'release-0.1'","Warn: 'last push approval' is disable on branch 'main'","Warn: 'last push approval' is disable on branch 'release-1.5'","Warn: 'last push approval' is disable on branch 'release-1.4'","Warn: 'last push approval' is disable on branch 'release-1.3'","Warn: 'last push approval' is disable on branch 'release-1.2'","Warn: 'last push approval' is disable on branch 'release-1.1'","Warn: 'last push approval' is disable on branch 'release-1.0'","Warn: 'last push approval' is disable on branch 'release-0.6'","Warn: 'last push approval' is disable on branch 'release-0.5'","Warn: 'last push approval' is disable on branch 'release-0.4'","Warn: 'last push approval' is disable on branch 'release-0.3'","Warn: 'last push approval' is disable on branch 'release-0.2'","Warn: 'last push approval' is disable on branch 'release-0.1'","Info: 'up-to-date branches' is required to merge on branch 'main'","Info: 'up-to-date branches' is required to merge on branch 'release-1.5'","Info: 'up-to-date branches' is required to merge on branch 'release-1.4'","Info: 'up-to-date branches' is required to merge on branch 'release-1.3'","Info: 'up-to-date branches' is required to merge on branch 'release-1.2'","Info: 'up-to-date branches' is required to merge on branch 'release-1.1'","Info: 'up-to-date branches' is required to merge on branch 'release-1.0'","Info: 'up-to-date branches' is required to merge on branch 'release-0.6'","Info: 'up-to-date branches' is required to merge on branch 'release-0.5'","Info: 'up-to-date branches' is required to merge on branch 'release-0.4'","Info: 'up-to-date branches' is required to merge on branch 'release-0.3'","Info: 'up-to-date branches' is required to merge on branch 'release-0.2'","Info: 'up-to-date branches' is required to merge on branch 'release-0.1'","Info: status check found to merge onto on branch 'main'","Info: status check found to merge onto on branch 'release-1.5'","Info: status check found to merge onto on branch 'release-1.4'","Info: status check found to merge onto on branch 'release-1.3'","Info: status check found to merge onto on branch 'release-1.2'","Info: status check found to merge onto on branch 'release-1.1'","Info: status check found to merge onto on branch 'release-1.0'","Info: status check found to merge onto on branch 'release-0.6'","Info: status check found to merge onto on branch 'release-0.5'","Info: status check found to merge onto on branch 'release-0.4'","Info: status check found to merge onto on branch 'release-0.3'","Info: status check found to merge onto on branch 'release-0.2'","Info: status check found to merge onto on branch 'release-0.1'","Info: PRs are required in order to make changes on branch 'main'","Info: PRs are required in order to make changes on branch 'release-1.5'","Info: PRs are required in order to make changes on branch 'release-1.4'","Info: PRs are required in order to make changes on branch 'release-1.3'","Info: PRs are required in order to make changes on branch 'release-1.2'","Info: PRs are required in order to make changes on branch 'release-1.1'","Info: PRs are required in order to make changes on branch 'release-1.0'","Info: PRs are required in order to make changes on branch 'release-0.6'","Info: PRs are required in order to make changes on branch 'release-0.5'","Info: PRs are required in order to make changes on branch 'release-0.4'","Info: PRs are required in order to make changes on branch 'release-0.3'","Info: PRs are required in order to make changes on branch 'release-0.2'","Info: PRs are required in order to make changes on branch 'release-0.1'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#branch-protection"}},{"name":"CI-Tests","score":10,"reason":"30 out of 30 merged PRs checked by a CI test -- score normalized to 10","details":null,"documentation":{"short":"Determines if the project runs tests before pull requests are merged.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#ci-tests"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#cii-best-practices"}},{"name":"Code-Review","score":10,"reason":"all changesets reviewed","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#code-review"}},{"name":"Contributors","score":10,"reason":"project has 7 contributing companies or organizations","details":["Info: apache contributor org/company found, ray-project contributor org/company found, apache @anyscale contributor org/company found, nginx contributor org/company found, nginxinc contributor org/company found, opentracing-contrib contributor org/company found, f5 networks contributor org/company found, "],"documentation":{"short":"Determines if the project has a set of contributors from multiple organizations (e.g., companies).","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#contributors"}},{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#dangerous-workflow"}},{"name":"Dependency-Update-Tool","score":10,"reason":"update tool detected","details":["Info: detected update tool: RenovateBot: renovate.json:1"],"documentation":{"short":"Determines if the project uses a dependency update tool.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#dependency-update-tool"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#fuzzing"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: Apache License 2.0: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#license"}},{"name":"Maintained","score":10,"reason":"30 commit(s) and 22 issue activity found in the last 90 days -- score normalized to 10","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#maintained"}},{"name":"Packaging","score":10,"reason":"packaging workflow detected","details":["Info: Project packages its releases by way of GitHub Actions.: .github/workflows/ci.yml:129"],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#packaging"}},{"name":"Pinned-Dependencies","score":7,"reason":"dependency not pinned by hash detected -- score normalized to 7","details":["Warn: containerImage not pinned by hash: build/Dockerfile:2","Warn: containerImage not pinned by hash: build/Dockerfile:12","Warn: containerImage not pinned by hash: build/Dockerfile:14","Warn: containerImage not pinned by hash: build/Dockerfile:17","Warn: containerImage not pinned by hash: build/Dockerfile:21","Warn: containerImage not pinned by hash: build/Dockerfile:25","Warn: containerImage not pinned by hash: build/Dockerfile:39","Warn: containerImage not pinned by hash: build/Dockerfile:42","Warn: containerImage not pinned by hash: build/Dockerfile:45","Warn: containerImage not pinned by hash: build/Dockerfile.nginx:2: pin your Docker image by updating nginx:1.27.3-alpine-otel to nginx:1.27.3-alpine-otel@sha256:842785ec7ce7800f1f378cd115661f78dfce99362766a1f62292121819a8ed73","Warn: containerImage not pinned by hash: build/Dockerfile.nginxplus:8: pin your Docker image by updating alpine:3.20 to alpine:3.20@sha256:1e42bbe2508154c9126d48c2b8a75420c3544343bf86fd041fb7527e017a4b4a","Warn: containerImage not pinned by hash: debug/Dockerfile:4","Warn: containerImage not pinned by hash: debug/Dockerfile:8: pin your Docker image by updating alpine:latest to alpine:latest@sha256:21dc6063fd678b478f57c0e13f47560d0ea4eeba26dfc947b2a4f81f686b9f45","Warn: containerImage not pinned by hash: tests/conformance/Dockerfile:2: pin your Docker image by updating golang:1.23 to golang:1.23@sha256:7ea4c9dcb2b97ff8ee80a67db3d44f98c8ffa0d191399197007d8459c1453041","Warn: containerImage not pinned by hash: tests/framework/crossplane/Dockerfile:2","Warn: containerImage not pinned by hash: tests/framework/crossplane/Dockerfile:13: pin your Docker image by updating alpine to alpine@sha256:21dc6063fd678b478f57c0e13f47560d0ea4eeba26dfc947b2a4f81f686b9f45","Warn: goCommand not pinned by hash: debug/Dockerfile:6","Info:  58 out of  58 GitHub-owned GitHubAction dependencies pinned","Info:  59 out of  59 third-party GitHubAction dependencies pinned","Info:   0 out of  16 containerImage dependencies pinned","Info:   0 out of   1 goCommand dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#pinned-dependencies"}},{"name":"SAST","score":10,"reason":"SAST tool is run on all commits","details":["Info: SAST configuration detected: CodeQL","Info: all commits (30) are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#sast"}},{"name":"Security-Policy","score":10,"reason":"security policy file detected","details":["Info: security policy file detected: SECURITY.md:1","Info: Found linked content: SECURITY.md:1","Info: Found disclosure, vulnerability, and/or timelines in security policy: SECURITY.md:1","Info: Found text in security policy: SECURITY.md:1"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#security-policy"}},{"name":"Signed-Releases","score":8,"reason":"5 out of the last 5 releases have a total of 5 signed artifacts.","details":["Info: signed release artifact: nginx-gateway-fabric_1.5.1_checksums.txt.sig: https://api.github.com/repos/nginxinc/nginx-gateway-fabric/releases/assets/213772212","Info: signed release artifact: nginx-gateway-fabric_1.5.0_checksums.txt.sig: https://api.github.com/repos/nginxinc/nginx-gateway-fabric/releases/assets/207914521","Info: signed release artifact: nginx-gateway-fabric_1.4.0_checksums.txt.sig: https://api.github.com/repos/nginxinc/nginx-gateway-fabric/releases/assets/187217378","Info: signed release artifact: nginx-gateway-fabric_1.3.0_checksums.txt.sig: https://api.github.com/repos/nginxinc/nginx-gateway-fabric/releases/assets/173188482","Info: signed release artifact: nginx-gateway-fabric_1.2.0_checksums.txt.sig: https://api.github.com/repos/nginxinc/nginx-gateway-fabric/releases/assets/157903675","Warn: release artifact v1.5.1 does not have provenance: https://api.github.com/repos/nginxinc/nginx-gateway-fabric/releases/190695703","Warn: release artifact v1.5.0 does not have provenance: https://api.github.com/repos/nginxinc/nginx-gateway-fabric/releases/185692127","Warn: release artifact v1.4.0 does not have provenance: https://api.github.com/repos/nginxinc/nginx-gateway-fabric/releases/170570165","Warn: release artifact v1.3.0 does not have provenance: https://api.github.com/repos/nginxinc/nginx-gateway-fabric/releases/159348665","Warn: release artifact v1.2.0 does not have provenance: https://api.github.com/repos/nginxinc/nginx-gateway-fabric/releases/147602611"],"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#signed-releases"}},{"name":"Token-Permissions","score":10,"reason":"GitHub workflow tokens follow principle of least privilege","details":["Info: jobLevel 'contents' permission set to 'read': .github/workflows/build.yml:26","Info: jobLevel 'contents' permission set to 'read': .github/workflows/ci.yml:205","Warn: jobLevel 'security-events' permission set to 'write': .github/workflows/ci.yml:206","Info: jobLevel 'contents' permission set to 'read': .github/workflows/ci.yml:219","Warn: jobLevel 'security-events' permission set to 'write': .github/workflows/ci.yml:220","Info: jobLevel 'contents' permission set to 'read': .github/workflows/ci.yml:243","Info: jobLevel 'contents' permission set to 'read': .github/workflows/ci.yml:292","Info: jobLevel 'packages' permission set to 'read': .github/workflows/codeql-analysis.yml:25","Info: jobLevel 'actions' permission set to 'read': .github/workflows/codeql-analysis.yml:26","Info: jobLevel 'contents' permission set to 'read': .github/workflows/codeql-analysis.yml:27","Info: jobLevel 'contents' permission set to 'read': .github/workflows/dependency-review.yml:11","Info: jobLevel 'contents' permission set to 'read': .github/workflows/docs-build-push.yml:52","Warn: jobLevel 'actions' permission set to 'write': .github/workflows/f5-cla.yml:24","Info: jobLevel 'contents' permission set to 'read': .github/workflows/f5-cla.yml:25","Warn: jobLevel 'statuses' permission set to 'write': .github/workflows/f5-cla.yml:27","Info: jobLevel 'contents' permission set to 'read': .github/workflows/labeler.yml:11","Info: jobLevel 'contents' permission set to 'read': .github/workflows/nfr.yml:61","Info: jobLevel 'contents' permission set to 'read': .github/workflows/nfr.yml:76","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/nfr.yml:167","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/release-pr.yml:22","Info: jobLevel 'pull-requests' permission set to 'read': .github/workflows/renovate-build.yml:25","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/renovate-build.yml:45","Info: jobLevel 'contents' permission set to 'read': .github/workflows/update-docker-images.yml:85","Warn: jobLevel 'security-events' permission set to 'write': .github/workflows/update-docker-images.yml:86","Warn: jobLevel 'packages' permission set to 'write': .github/workflows/update-docker-images.yml:87","Info: topLevel 'contents' permission set to 'read': .github/workflows/build.yml:21","Info: topLevel 'contents' permission set to 'read': .github/workflows/ci.yml:25","Info: topLevel 'contents' permission set to 'read': .github/workflows/codeql-analysis.yml:20","Info: topLevel 'contents' permission set to 'read': .github/workflows/conformance.yml:25","Info: topLevel 'contents' permission set to 'read': .github/workflows/dependency-review.yml:5","Info: topLevel 'contents' permission set to 'read': .github/workflows/docs-build-push.yml:31","Info: topLevel 'contents' permission set to 'read': .github/workflows/f5-cla.yml:17","Info: topLevel 'contents' permission set to 'read': .github/workflows/fossa.yml:13","Info: topLevel 'contents' permission set to 'read': .github/workflows/functional.yml:21","Info: topLevel 'contents' permission set to 'read': .github/workflows/helm.yml:14","Info: topLevel 'contents' permission set to 'read': .github/workflows/labeler.yml:6","Info: topLevel 'contents' permission set to 'read': .github/workflows/lint.yml:20","Info: topLevel 'contents' permission set to 'read': .github/workflows/mend.yml:20","Info: topLevel 'contents' permission set to 'read': .github/workflows/nfr.yml:49","Info: topLevel 'contents' permission set to 'read': .github/workflows/release-pr.yml:16","Info: topLevel 'contents' permission set to 'read': .github/workflows/renovate-build.yml:8","Info: topLevel permissions set to 'read-all': .github/workflows/scorecards.yml:15","Info: topLevel 'contents' permission set to 'read': .github/workflows/stale.yml:7","Info: topLevel 'contents' permission set to 'read': .github/workflows/update-docker-images.yml:22"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#token-permissions"}},{"name":"Vulnerabilities","score":10,"reason":"0 existing vulnerabilities detected","details":null,"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#vulnerabilities"}}]}
