diff --git a/.github/workflows/pipeline.yml b/.github/workflows/pipeline.yml index 2d0a0ea..b1cd69a 100644 --- a/.github/workflows/pipeline.yml +++ b/.github/workflows/pipeline.yml @@ -14,7 +14,7 @@ on: jobs: fmt: - uses: ./.github/workflows/witness.yml + uses: testifysec/witness-run-action/.github/workflows/witness.yml@reusable-workflow with: pull_request: ${{ github.event_name == 'pull_request' }} step: fmt @@ -22,20 +22,23 @@ jobs: command: go fmt ./... vet: - uses: ./.github/workflows/witness.yml + uses: testifysec/witness-run-action/.github/workflows/witness.yml@reusable-workflow with: pull_request: ${{ github.event_name == 'pull_request' }} step: vet attestations: "git github environment" + archivista-server: "https://judge-api.aws-sandbox-staging.testifysec.dev" command: go vet ./... # --ignore DL3002 lint: - uses: ./.github/workflows/witness.yml + uses: testifysec/witness-run-action/.github/workflows/witness.yml@reusable-workflow with: pull_request: ${{ github.event_name == 'pull_request' }} step: lint + pre-command-attestations: "git github environment" attestations: "git github environment" + archivista-server: "https://judge-api.aws-sandbox-staging.testifysec.dev" pre-command: | curl -sSfL https://github.com/hadolint/hadolint/releases/download/v2.12.0/hadolint-Linux-x86_64 -o /usr/local/bin/hadolint && \ chmod +x /usr/local/bin/hadolint @@ -45,22 +48,25 @@ jobs: unit-test: needs: [ fmt, vet, lint ] - uses: ./.github/workflows/witness.yml + uses: testifysec/witness-run-action/.github/workflows/witness.yml@reusable-workflow with: pull_request: ${{ github.event_name == 'pull_request' }} step: unit-test attestations: "git github environment" + archivista-server: "https://judge-api.aws-sandbox-staging.testifysec.dev" command: go test ./... -coverprofile cover.out artifact-upload-name: cover.out artifact-upload-path: cover.out sast: needs: [ fmt, vet, lint ] - uses: ./.github/workflows/witness.yml + uses: testifysec/witness-run-action/.github/workflows/witness.yml@reusable-workflow with: pull_request: ${{ github.event_name == 'pull_request' }} step: sast + pre-command-attestations: "git github environment" attestations: "git github environment" + archivista-server: "https://judge-api.aws-sandbox-staging.testifysec.dev" pre-command: python3 -m pip install semgrep==1.45.0 command: semgrep scan --config auto ./ --sarif -o semgrep.sarif artifact-upload-name: semgrep.sarif @@ -68,7 +74,7 @@ jobs: build: needs: [ unit-test, sast ] - uses: ./.github/workflows/witness.yml + uses: testifysec/witness-run-action/.github/workflows/witness.yml@reusable-workflow with: pull_request: ${{ github.event_name == 'pull_request' }} step: build @@ -109,10 +115,12 @@ jobs: use: true - name: Build Image - uses: testifysec/witness-run-action@9bb3541332161bc8bf76c36bcdaab56b8da8e171 # v0.2.0-beta + uses: testifysec/witness-run-action@reusable-workflow # v0.2.0 with: + version: 0.6.0 step: build-image attestations: "git github environment slsa" + archivista-server: "https://judge-api.aws-sandbox-staging.testifysec.dev" command: | /bin/sh -c "docker buildx build --platform linux/amd64,linux/arm64 -t ${{ steps.meta.outputs.tags }} --push ." outputs: @@ -120,11 +128,12 @@ jobs: save-image: needs: build-image - uses: ./.github/workflows/witness.yml + uses: testifysec/witness-run-action/.github/workflows/witness.yml@reusable-workflow with: pull_request: ${{ github.event_name == 'pull_request' }} - step: save-image + step: save-image attestations: "git github environment slsa oci" + archivista-server: "https://judge-api.aws-sandbox-staging.testifysec.dev" command: | docker pull ${{ needs.build-image.outputs.tags }} && docker save ${{ needs.build-image.outputs.tags }} -o image.tar artifact-upload-name: image.tar @@ -132,41 +141,30 @@ jobs: generate-sbom: needs: save-image - uses: ./.github/workflows/witness.yml + uses: testifysec/witness-run-action/.github/workflows/witness.yml@reusable-workflow with: pull_request: ${{ github.event_name == 'pull_request' }} step: generate-sbom - attestations: "git github environment" + pre-command-attestations: "git github environment" + attestations: "git github environment sbom" + archivista-server: "https://judge-api.aws-sandbox-staging.testifysec.dev" artifact-download: image.tar pre-command: | curl -sSfL https://raw.githubusercontent.com/anchore/syft/main/install.sh | sh -s -- -b /usr/local/bin command: | - syft packages docker-archive:/tmp/image.tar -o spdx-json --file syft.spdx.json - artifact-upload-name: syft.spdx.json - artifact-upload-path: syft.spdx.json - - cve-scan: - needs: save-image - uses: ./.github/workflows/witness.yml - with: - pull_request: ${{ github.event_name == 'pull_request' }} - step: cve-scan - attestations: "git github environment" - artifact-download: image.tar - pre-command: | - curl -sSfL https://raw.githubusercontent.com/anchore/grype/main/install.sh | sh -s -- -b /usr/local/bin - command: | - grype docker-archive:/tmp/image.tar -o sarif --file grype.sarif - artifact-upload-name: grype.sarif - artifact-upload-path: grype.sarif + syft packages docker-archive:/tmp/image.tar --source-name=pkg:oci/testifysec/swf -o cyclonedx-json --file sbom.cdx.json + artifact-upload-name: sbom.cdx.json + artifact-upload-path: sbom.cdx.json secret-scan: needs: save-image - uses: ./.github/workflows/witness.yml + uses: testifysec/witness-run-action/.github/workflows/witness.yml@reusable-workflow with: pull_request: ${{ github.event_name == 'pull_request' }} step: secret-scan + pre-command-attestations: "git github environment" attestations: "git github environment" + archivista-server: "https://judge-api.aws-sandbox-staging.testifysec.dev" artifact-download: image.tar pre-command: | curl -sSfL https://raw.githubusercontent.com/trufflesecurity/trufflehog/main/scripts/install.sh | sh -s -- -b /usr/local/bin @@ -176,17 +174,19 @@ jobs: artifact-upload-path: trufflehog.json verify: - needs: [ generate-sbom, cve-scan, secret-scan] + needs: [ generate-sbom, secret-scan] if: ${{ github.event_name == 'push' }} - uses: ./.github/workflows/witness.yml + uses: testifysec/witness-run-action/.github/workflows/witness.yml@reusable-workflow with: pull_request: ${{ github.event_name == 'pull_request' }} step: verify + pre-command-attestations: "git github environment" attestations: "git github environment" + archivista-server: "https://judge-api.aws-sandbox-staging.testifysec.dev" artifact-download: image.tar pre-command: | - curl -sSfL https://github.com/in-toto/witness/releases/download/v0.4.0-beta/witness_0.4.0-beta_linux_amd64.tar.gz -o witness.tar.gz && \ + curl -sSfL https://github.com/in-toto/witness/releases/download/v0.6.0/witness_0.6.0_linux_amd64.tar.gz -o witness.tar.gz && \ tar -xzvf witness.tar.gz -C /usr/local/bin/ && rm ./witness.tar.gz command: | witness verify -p policy-signed.json -k swfpublic.pem -f /tmp/image.tar --enable-archivista -l debug diff --git a/.github/workflows/witness.yml b/.github/workflows/witness.yml deleted file mode 100644 index f41bc50..0000000 --- a/.github/workflows/witness.yml +++ /dev/null @@ -1,80 +0,0 @@ -# Copyright 2023 The Archivista Contributors -# -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -# See the License for the specific language governing permissions and -# limitations under the License. - -on: - workflow_call: - inputs: - pull_request: - required: true - type: boolean - artifact-download: - required: false - type: string - artifact-upload-name: - required: false - type: string - artifact-upload-path: - required: false - type: string - pre-command: - required: false - type: string - command: - required: true - type: string - step: - required: true - type: string - attestations: - required: true - type: string - -jobs: - witness: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - - uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 - with: - go-version: 1.21.x - - - if: ${{ inputs.artifact-download != '' }} - uses: actions/download-artifact@6b208ae046db98c579e8a3aa621ab581ff575935 # v4.1.1 - with: - name: ${{ inputs.artifact-download }} - path: /tmp - - - if: ${{ inputs.pre-command != '' && inputs.pull_request == false }} - uses: testifysec/witness-run-action@9bb3541332161bc8bf76c36bcdaab56b8da8e171 # v0.2.0-beta - with: - step: pre-${{ inputs.step }} - attestations: ${{ inputs.attestations }} - command: /bin/sh -c "${{ inputs.pre-command }}" - - if: ${{ inputs.pre-command != '' && inputs.pull_request == true }} - run: ${{ inputs.pre-command }} - - - if: ${{ inputs.pull_request == false }} - uses: testifysec/witness-run-action@9bb3541332161bc8bf76c36bcdaab56b8da8e171 # v0.2.0-beta - with: - step: ${{ inputs.step }} - attestations: ${{ inputs.attestations }} - command: /bin/sh -c "${{ inputs.command }}" - - if: ${{ inputs.pull_request == true }} - run: ${{ inputs.command }} - - - if: ${{ inputs.artifact-upload-path != '' && inputs.artifact-upload-name != ''}} - uses: actions/upload-artifact@26f96dfa697d77e81fd5907df203aa23a56210a8 # v4.3.0 - with: - name: ${{ inputs.artifact-upload-name }} - path: ${{ inputs.artifact-upload-path }} diff --git a/policy-signed.json b/policy-signed.json index 594d3db..26edba0 100644 --- a/policy-signed.json +++ b/policy-signed.json @@ -1 +1 @@ -{"payload":"{
    "expires": "2025-12-17T23:57:40-05:00",
    "steps": {
      "fmt": {
        "name": "fmt",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa",
                "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "vet": {
        "name": "vet",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ]
            }
          }
        ]
      },
      "lint": {
        "name": "lint",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1",
            "regopolicies": [
              {
                "name": "expected command",
                "module": "cGFja2FnZSBjb21tYW5kcnVuLmNtZAoKZGVueVttc2ddIHsKCWlucHV0LmNtZCAhPSBbIi9iaW4vc2giLCAiLWMiLCAiaGFkb2xpbnQgLWYgc2FyaWYgRG9ja2VyZmlsZSA+IGhhZG9saW50LnNhcmlmIl0KCW1zZyA6PSAidW5leHBlY3RlZCBjbWQiCn0K"
              }
            ]
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa",
                "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "unit-test": {
        "name": "unit-test",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa",
                "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "sast": {
        "name": "sast",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa",
                "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "build-image": {
        "name": "build-image",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://slsa.dev/provenance/v1.0"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa",
                "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "save-image": {
        "name": "save-image",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://slsa.dev/provenance/v1.0"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa",
                "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "generate-sbom": {
        "name": "generate-sbom",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa",
                "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "cve-scan": {
        "name": "cve-scan",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa",
                "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "secret-scan": {
        "name": "secret-scan",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa",
                "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      }
    },
    "roots": {
      "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159": {
        "certificate": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUNHakNDQWFHZ0F3SUJBZ0lVQUxuVmlWZm5VMGJySmFzbVJrSHJuL1VuZmFRd0NnWUlLb1pJemowRUF3TXcKS2pFVk1CTUdBMVVFQ2hNTWMybG5jM1J2Y21VdVpHVjJNUkV3RHdZRFZRUURFd2h6YVdkemRHOXlaVEFlRncweQpNakEwTVRNeU1EQTJNVFZhRncwek1URXdNRFV4TXpVMk5UaGFNRGN4RlRBVEJnTlZCQW9UREhOcFozTjBiM0psCkxtUmxkakVlTUJ3R0ExVUVBeE1WYzJsbmMzUnZjbVV0YVc1MFpYSnRaV1JwWVhSbE1IWXdFQVlIS29aSXpqMEMKQVFZRks0RUVBQ0lEWWdBRThSVlMveXNIK05PdnVEWnlQSVp0aWxnVUY5TmxhcllwQWQ5SFAxdkJCSDFVNUNWNwo3TFNTN3MwWmlING5FN0h2N3B0UzZMdnZSL1NUazc5OExWZ016TGxKNEhlSWZGM3RIU2FleExjWXBTQVNyMWtTCjBOL1JnQkp6LzlqV0NpWG5vM3N3ZVRBT0JnTlZIUThCQWY4RUJBTUNBUVl3RXdZRFZSMGxCQXd3Q2dZSUt3WUIKQlFVSEF3TXdFZ1lEVlIwVEFRSC9CQWd3QmdFQi93SUJBREFkQmdOVkhRNEVGZ1FVMzlQcHoxWWtFWmI1cU5qcApLRldpeGk0WVpEOHdId1lEVlIwakJCZ3dGb0FVV01BZVg1RkZwV2FwZXN5UW9aTWkwQ3JGeGZvd0NnWUlLb1pJCnpqMEVBd01EWndBd1pBSXdQQ3NRSzREWWlaWURQSWFEaTVIRktuZnhYeDZBU1NWbUVSZnN5bllCaVgyWDZTSlIKblpVODQvOURaZG5GdnZ4bUFqQk90NlFwQmxjNEovMER4dmtUQ3FwY2x2emlMNkJDQ1BuamRsSUIzUHUzQnhzUApteWdVWTdJaTJ6YmRDZGxpaW93PQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCgo=",
        "intermediates": [
          "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUI5ekNDQVh5Z0F3SUJBZ0lVQUxaTkFQRmR4SFB3amVEbG9Ed3lZQ2hBTy80d0NnWUlLb1pJemowRUF3TXcKS2pFVk1CTUdBMVVFQ2hNTWMybG5jM1J2Y21VdVpHVjJNUkV3RHdZRFZRUURFd2h6YVdkemRHOXlaVEFlRncweQpNVEV3TURjeE16VTJOVGxhRncwek1URXdNRFV4TXpVMk5UaGFNQ294RlRBVEJnTlZCQW9UREhOcFozTjBiM0psCkxtUmxkakVSTUE4R0ExVUVBeE1JYzJsbmMzUnZjbVV3ZGpBUUJnY3Foa2pPUFFJQkJnVXJnUVFBSWdOaUFBVDcKWGVGVDRyYjNQUUd3UzRJYWp0TGszL09sbnBnYW5nYUJjbFlwc1lCcjVpKzR5bkIwN2NlYjNMUDBPSU9aZHhleApYNjljNWlWdXlKUlErSHowNXlpK1VGM3VCV0FsSHBpUzVzaDArSDJHSEU3U1hyazFFQzVtMVRyMTlMOWdnOTJqCll6QmhNQTRHQTFVZER3RUIvd1FFQXdJQkJqQVBCZ05WSFJNQkFmOEVCVEFEQVFIL01CMEdBMVVkRGdRV0JCUlkKd0I1ZmtVV2xacWw2ekpDaGt5TFFLc1hGK2pBZkJnTlZIU01FR0RBV2dCUll3QjVma1VXbFpxbDZ6SkNoa3lMUQpLc1hGK2pBS0JnZ3Foa2pPUFFRREF3TnBBREJtQWpFQWoxbkhlWFpwKzEzTldCTmErRURzRFA4RzFXV2cxdENNCldQL1dIUHFwYVZvMGpoc3dlTkZaZ1NzMGVFN3dZSTRxQWpFQTJXQjlvdDk4c0lrb0YzdlpZZGQzL1Z0V0I1YjkKVE5NZWE3SXgvc3RKNVRmY0xMZUFCTEU0Qk5KT3NRNHZuQkhKCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K"
        ]
      }
    },
    "timestampauthorities": {
      "freetsa": {
        "certificate": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUgvekNDQmVlZ0F3SUJBZ0lKQU1IcGhoWU5xT21BTUEwR0NTcUdTSWIzRFFFQkRRVUFNSUdWTVJFd0R3WUQKVlFRS0V3aEdjbVZsSUZSVFFURVFNQTRHQTFVRUN4TUhVbTl2ZENCRFFURVlNQllHQTFVRUF4TVBkM2QzTG1aeQpaV1YwYzJFdWIzSm5NU0l3SUFZSktvWklodmNOQVFrQkZoTmlkWE5wYkdWNllYTkFaMjFoYVd3dVkyOXRNUkl3CkVBWURWUVFIRXdsWGRXVnllbUoxY21jeER6QU5CZ05WQkFnVEJrSmhlV1Z5YmpFTE1Ba0dBMVVFQmhNQ1JFVXcKSGhjTk1UWXdNekV6TURFMU1qRXpXaGNOTkRFd016QTNNREUxTWpFeldqQ0JsVEVSTUE4R0ExVUVDaE1JUm5KbApaU0JVVTBFeEVEQU9CZ05WQkFzVEIxSnZiM1FnUTBFeEdEQVdCZ05WQkFNVEQzZDNkeTVtY21WbGRITmhMbTl5Clp6RWlNQ0FHQ1NxR1NJYjNEUUVKQVJZVFluVnphV3hsZW1GelFHZHRZV2xzTG1OdmJURVNNQkFHQTFVRUJ4TUoKVjNWbGNucGlkWEpuTVE4d0RRWURWUVFJRXdaQ1lYbGxjbTR4Q3pBSkJnTlZCQVlUQWtSRk1JSUNJakFOQmdrcQpoa2lHOXcwQkFRRUZBQU9DQWc4QU1JSUNDZ0tDQWdFQXRnS09EakF5OFJFUTJXVE5xVXVkQW5qaGxDcnBFNnFsCm1RZk5wcGVUbVZ2WnJINHp1dG4rTndUYUhBR3BqU0d2NC9XUnBaMXdaM0JSWjVtUFVCWnlMZ3EwWXJJZlE1RngKMHMvTVJaUHpjMXIzbEtXck1SOXNBUXg0bU40ejExeEZFTzUyOUwwZEZKalBGOU1EOEdwZDJmZVd6R3lwdGxlbApiK1BxVCsrK2ZPYTJvWTArTmFNTTdsL3hjTkhQT2FNejAvMm9sazBpMjJoYktlVmh2b2tQQ3FoRmh6c3VoS3NtCnE0T2Yvbyt0NmRJN3N4NWgwblBNbTRnR1NSaGZxK3o2QlRSZ0NycVFHMkZPTG9WRmd0NmlJbS9Cbk5mZlVyN1YKRFlkM3pabUl3Rk9qL0gzREtIb0dpay94SzNFODJZQTJadWxWT0ZSVy96ajRBcGpQYTVPRmJwSWtkMHBtenh6ZApFY0w0NzloU0E5ZEZpeVZtU3hQdFk1emUxUCtCRTliTVUxUFNjcFJ6dzhNSEZYeHlLcVcxM1F2N0xXdzRzYmszClNjaUI3R0FDYlFpVkd6Z2t2WEc2eTg1SE91dldOdkM1R0xTaXlQOUdsUEIwVjY4dGJ4ejRKVlRSZHcvWG4vWFQKRk56UkJNM2NxOGxCT0FWdC9QQVg1K3VGY3YxUzl3RkU4WWphQmZXQ1AxamRCaWwrYzRlKzB0ZHl3VDJvSm1ZQgpCRi9rRXQxd21Hd01tSHVuTkV1UU56aDFGdEpZNTRoYlVmaVdpMzhtQVNFN3hNdE1oZmovQzRTdmFwaUROODM3CmdZYVBmczh4M0taeGJYN0MzWUFzRm5KaW5sd0FVc3MxZmRLYXI4US9ZVnM3SC9uVTRjNEl4eHh6NGY2N2ZjVnEKTTJJVEtlbnRiQ01DQXdFQUFhT0NBazR3Z2dKS01Bd0dBMVVkRXdRRk1BTUJBZjh3RGdZRFZSMFBBUUgvQkFRRApBZ0hHTUIwR0ExVWREZ1FXQkJUNlZRMk1OR1pSUTB6MzU3T25iSld2ZXVha2x6Q0J5Z1lEVlIwakJJSENNSUcvCmdCVDZWUTJNTkdaUlEwejM1N09uYkpXdmV1YWtsNkdCbTZTQm1EQ0JsVEVSTUE4R0ExVUVDaE1JUm5KbFpTQlUKVTBFeEVEQU9CZ05WQkFzVEIxSnZiM1FnUTBFeEdEQVdCZ05WQkFNVEQzZDNkeTVtY21WbGRITmhMbTl5WnpFaQpNQ0FHQ1NxR1NJYjNEUUVKQVJZVFluVnphV3hsZW1GelFHZHRZV2xzTG1OdmJURVNNQkFHQTFVRUJ4TUpWM1ZsCmNucGlkWEpuTVE4d0RRWURWUVFJRXdaQ1lYbGxjbTR4Q3pBSkJnTlZCQVlUQWtSRmdna0F3ZW1HRmcybzZZQXcKTXdZRFZSMGZCQ3d3S2pBb29DYWdKSVlpYUhSMGNEb3ZMM2QzZHk1bWNtVmxkSE5oTG05eVp5OXliMjkwWDJOaApMbU55YkRDQnp3WURWUjBnQklISE1JSEVNSUhCQmdvckJnRUVBWUh5SkFFQk1JR3lNRE1HQ0NzR0FRVUZCd0lCCkZpZG9kSFJ3T2k4dmQzZDNMbVp5WldWMGMyRXViM0puTDJaeVpXVjBjMkZmWTNCekxtaDBiV3d3TWdZSUt3WUIKQlFVSEFnRVdKbWgwZEhBNkx5OTNkM2N1Wm5KbFpYUnpZUzV2Y21jdlpuSmxaWFJ6WVY5amNITXVjR1JtTUVjRwpDQ3NHQVFVRkJ3SUNNRHNhT1VaeVpXVlVVMEVnZEhKMWMzUmxaQ0IwYVcxbGMzUmhiWEJwYm1jZ1UyOW1kSGRoCmNtVWdZWE1nWVNCVFpYSjJhV05sSUNoVFlXRlRLVEEzQmdnckJnRUZCUWNCQVFRck1Da3dKd1lJS3dZQkJRVUgKTUFHR0cyaDBkSEE2THk5M2QzY3VabkpsWlhSellTNXZjbWM2TWpVMk1EQU5CZ2txaGtpRzl3MEJBUTBGQUFPQwpBZ0VBYUs5K3Y1T0ZZdTlNNnp0WUMrTDY5c3cxb21keWxpODlsWkFmcFdNTWg5Q1JtSmhNNktCcU0vaXB3b0x0Cm54eXhHc2JDUGhjUWp1VHZ6bSt5bE42VndUTW1JbFZ5VlNMS1laY2RTanQvZUNVTis0MUs3c0Q3R1ZteFpCQUYKSUxuQkRtVEdKbUxrclUwS3V1SXBqOGxJL0U2WjZObm11UDIrUkFRU0hzZkJRaTZzc3NuWE1vNEhPVzVndFBPNwpnRHJVcFZYSUQrKzFQNFhuZGtvS243U3Z3NW4welM5ZnYxaHhCY1lJSFBQUVV6ZTJ1MzBiQVF0MG4waUl5Ukx6CmFXdWh0cEF0ZDdmZndFYkFTZ3pCN0UrTkdGNHRwVjM3ZThLaUEyeGlHU1JxVDVuZHUyOGZncE9ZODdnRDNBcloKRGN0WnZ2VENmSGRBUzVrRU8zZ25HR2VaRVZMRG1mRXN2OFRHSmEzQWxqVmE1RTQwSVFEc1VYcFFMaThHK1VDNAoxRFdadThFVlQ0cm5ZYUN3MVZYN1NoT1IxUE5DQ3ZqYjhTOHRmZHVkZDl6aFUzZ0VCMHJ4ZGVUeTF0VmJOTFhXCjk5eTkweGN3cjFaSURVd00veFEvbm9POEZSaG0wTG9QQzczRWYrSjRaQmRydld3YXVGM3pKZTMzZDRpYnhFY2IKOC9wejVXekZrZWl4WU0ybnNIaHFIc0JLdzdKUG91S05YUm5sNUlBRTFlRm1xRHlDN0cvVlQ3T0Y2Njl4TTZoYgpVdDVHMjFKRTRjTks2Tk51Y1MrZnpnMUpQWDArM1Zoc1laamo3RDV1bGpSdlFYcko4aUhnci9NNmoyb0xIdlRBCkkyTUxkcTJxalpGRE9DWHN4QnhKcGJtTEdCeDlvdzZaZXJsVXh6d3MyQVd2MnBrPQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg=="
      }
    }
  }
","payloadType":"https://witness.testifysec.com/policy/v0.1","signatures":[{"keyid":"6516d0812cb5a0d01f7f014f88e04c5d4c2d89a64e788a12950ba950fb43ef45","sig":"d7tB7Ob453kQDNlgLBwXJeHkt34tjC8H8PZIetfwSdjVbZwMrGYyhI4npxdQ5If9h+ZCWzhn5+SN9ymL6LiBX2vZfoepR0dxNh1l6ZpJw91ZhuvsgCvkVpaIFeeCh6/fcCshlMGnNta7Lya7sAzX9WgC314tntO5cK9ASgMXezjIS4pScccAHb0powbdkwq42j2I0n915I+Spp1Ta/hyw2+gyLrLiL8lEGeQFc5UMRbsHSGl+rCfBw+ob2o1OtQN1atKvOane97hXI9AWiGujdLtUnkIf5gKEuvOyzf+ViKn9obg1iwqOOoqCjFqg2x/nnZ+polrRvmvQ8n1woQDfw=="}]} +{"payload":"{
    "expires": "2025-12-17T23:57:40-05:00",
    "steps": {
      "fmt": {
        "name": "fmt",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow",
                "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c",
                "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "vet": {
        "name": "vet",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow",
                "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c",
                "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "lint": {
        "name": "lint",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1",
            "regopolicies": [
              {
                "name": "expected command",
                "module": "cGFja2FnZSBjb21tYW5kcnVuLmNtZAoKZGVueVttc2ddIHsKCWlucHV0LmNtZCAhPSBbIi9iaW4vc2giLCAiLWMiLCAiaGFkb2xpbnQgLWYgc2FyaWYgRG9ja2VyZmlsZSA+IGhhZG9saW50LnNhcmlmIl0KCW1zZyA6PSAidW5leHBlY3RlZCBjbWQiCn0K"
              }
            ]
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow",
                "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c",
                "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "unit-test": {
        "name": "unit-test",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow",
                "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c",
                "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "sast": {
        "name": "sast",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow",
                "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c",
                "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "build-image": {
        "name": "build-image",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://slsa.dev/provenance/v1.0"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow",
                "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c",
                "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "save-image": {
        "name": "save-image",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://slsa.dev/provenance/v1.0"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow",
                "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c",
                "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "generate-sbom": {
        "name": "generate-sbom",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow",
                "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c",
                "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      },
      "secret-scan": {
        "name": "secret-scan",
        "attestations": [
          {
            "type": "https://witness.dev/attestations/environment/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/git/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/material/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/command-run/v0.1"
          },
          {
            "type": "https://witness.dev/attestations/product/v0.1"
          }
        ],
        "functionaries": [
          {
            "type": "root",
            "certConstraint": {
              "commonname": "*",
              "dnsnames": [
                "*"
              ],
              "emails": [
                "*"
              ],
              "organizations": [
                "*"
              ],
              "uris": [
                "*"
              ],
              "roots": [
                "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159"
              ],
              "extensions": {
                "issuer": "https://token.actions.githubusercontent.com",
                "source_repository_uri": "https://github.com/testifysec/swf",
                "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow",
                "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c",
                "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa",
                "runner_environment": "github-hosted"
              }
            }
          }
        ]
      }
    },
    "roots": {
      "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159": {
        "certificate": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUNHakNDQWFHZ0F3SUJBZ0lVQUxuVmlWZm5VMGJySmFzbVJrSHJuL1VuZmFRd0NnWUlLb1pJemowRUF3TXcKS2pFVk1CTUdBMVVFQ2hNTWMybG5jM1J2Y21VdVpHVjJNUkV3RHdZRFZRUURFd2h6YVdkemRHOXlaVEFlRncweQpNakEwTVRNeU1EQTJNVFZhRncwek1URXdNRFV4TXpVMk5UaGFNRGN4RlRBVEJnTlZCQW9UREhOcFozTjBiM0psCkxtUmxkakVlTUJ3R0ExVUVBeE1WYzJsbmMzUnZjbVV0YVc1MFpYSnRaV1JwWVhSbE1IWXdFQVlIS29aSXpqMEMKQVFZRks0RUVBQ0lEWWdBRThSVlMveXNIK05PdnVEWnlQSVp0aWxnVUY5TmxhcllwQWQ5SFAxdkJCSDFVNUNWNwo3TFNTN3MwWmlING5FN0h2N3B0UzZMdnZSL1NUazc5OExWZ016TGxKNEhlSWZGM3RIU2FleExjWXBTQVNyMWtTCjBOL1JnQkp6LzlqV0NpWG5vM3N3ZVRBT0JnTlZIUThCQWY4RUJBTUNBUVl3RXdZRFZSMGxCQXd3Q2dZSUt3WUIKQlFVSEF3TXdFZ1lEVlIwVEFRSC9CQWd3QmdFQi93SUJBREFkQmdOVkhRNEVGZ1FVMzlQcHoxWWtFWmI1cU5qcApLRldpeGk0WVpEOHdId1lEVlIwakJCZ3dGb0FVV01BZVg1RkZwV2FwZXN5UW9aTWkwQ3JGeGZvd0NnWUlLb1pJCnpqMEVBd01EWndBd1pBSXdQQ3NRSzREWWlaWURQSWFEaTVIRktuZnhYeDZBU1NWbUVSZnN5bllCaVgyWDZTSlIKblpVODQvOURaZG5GdnZ4bUFqQk90NlFwQmxjNEovMER4dmtUQ3FwY2x2emlMNkJDQ1BuamRsSUIzUHUzQnhzUApteWdVWTdJaTJ6YmRDZGxpaW93PQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCgo=",
        "intermediates": [
          "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUI5ekNDQVh5Z0F3SUJBZ0lVQUxaTkFQRmR4SFB3amVEbG9Ed3lZQ2hBTy80d0NnWUlLb1pJemowRUF3TXcKS2pFVk1CTUdBMVVFQ2hNTWMybG5jM1J2Y21VdVpHVjJNUkV3RHdZRFZRUURFd2h6YVdkemRHOXlaVEFlRncweQpNVEV3TURjeE16VTJOVGxhRncwek1URXdNRFV4TXpVMk5UaGFNQ294RlRBVEJnTlZCQW9UREhOcFozTjBiM0psCkxtUmxkakVSTUE4R0ExVUVBeE1JYzJsbmMzUnZjbVV3ZGpBUUJnY3Foa2pPUFFJQkJnVXJnUVFBSWdOaUFBVDcKWGVGVDRyYjNQUUd3UzRJYWp0TGszL09sbnBnYW5nYUJjbFlwc1lCcjVpKzR5bkIwN2NlYjNMUDBPSU9aZHhleApYNjljNWlWdXlKUlErSHowNXlpK1VGM3VCV0FsSHBpUzVzaDArSDJHSEU3U1hyazFFQzVtMVRyMTlMOWdnOTJqCll6QmhNQTRHQTFVZER3RUIvd1FFQXdJQkJqQVBCZ05WSFJNQkFmOEVCVEFEQVFIL01CMEdBMVVkRGdRV0JCUlkKd0I1ZmtVV2xacWw2ekpDaGt5TFFLc1hGK2pBZkJnTlZIU01FR0RBV2dCUll3QjVma1VXbFpxbDZ6SkNoa3lMUQpLc1hGK2pBS0JnZ3Foa2pPUFFRREF3TnBBREJtQWpFQWoxbkhlWFpwKzEzTldCTmErRURzRFA4RzFXV2cxdENNCldQL1dIUHFwYVZvMGpoc3dlTkZaZ1NzMGVFN3dZSTRxQWpFQTJXQjlvdDk4c0lrb0YzdlpZZGQzL1Z0V0I1YjkKVE5NZWE3SXgvc3RKNVRmY0xMZUFCTEU0Qk5KT3NRNHZuQkhKCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K"
        ]
      }
    },
    "timestampauthorities": {
      "freetsa": {
        "certificate": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUgvekNDQmVlZ0F3SUJBZ0lKQU1IcGhoWU5xT21BTUEwR0NTcUdTSWIzRFFFQkRRVUFNSUdWTVJFd0R3WUQKVlFRS0V3aEdjbVZsSUZSVFFURVFNQTRHQTFVRUN4TUhVbTl2ZENCRFFURVlNQllHQTFVRUF4TVBkM2QzTG1aeQpaV1YwYzJFdWIzSm5NU0l3SUFZSktvWklodmNOQVFrQkZoTmlkWE5wYkdWNllYTkFaMjFoYVd3dVkyOXRNUkl3CkVBWURWUVFIRXdsWGRXVnllbUoxY21jeER6QU5CZ05WQkFnVEJrSmhlV1Z5YmpFTE1Ba0dBMVVFQmhNQ1JFVXcKSGhjTk1UWXdNekV6TURFMU1qRXpXaGNOTkRFd016QTNNREUxTWpFeldqQ0JsVEVSTUE4R0ExVUVDaE1JUm5KbApaU0JVVTBFeEVEQU9CZ05WQkFzVEIxSnZiM1FnUTBFeEdEQVdCZ05WQkFNVEQzZDNkeTVtY21WbGRITmhMbTl5Clp6RWlNQ0FHQ1NxR1NJYjNEUUVKQVJZVFluVnphV3hsZW1GelFHZHRZV2xzTG1OdmJURVNNQkFHQTFVRUJ4TUoKVjNWbGNucGlkWEpuTVE4d0RRWURWUVFJRXdaQ1lYbGxjbTR4Q3pBSkJnTlZCQVlUQWtSRk1JSUNJakFOQmdrcQpoa2lHOXcwQkFRRUZBQU9DQWc4QU1JSUNDZ0tDQWdFQXRnS09EakF5OFJFUTJXVE5xVXVkQW5qaGxDcnBFNnFsCm1RZk5wcGVUbVZ2WnJINHp1dG4rTndUYUhBR3BqU0d2NC9XUnBaMXdaM0JSWjVtUFVCWnlMZ3EwWXJJZlE1RngKMHMvTVJaUHpjMXIzbEtXck1SOXNBUXg0bU40ejExeEZFTzUyOUwwZEZKalBGOU1EOEdwZDJmZVd6R3lwdGxlbApiK1BxVCsrK2ZPYTJvWTArTmFNTTdsL3hjTkhQT2FNejAvMm9sazBpMjJoYktlVmh2b2tQQ3FoRmh6c3VoS3NtCnE0T2Yvbyt0NmRJN3N4NWgwblBNbTRnR1NSaGZxK3o2QlRSZ0NycVFHMkZPTG9WRmd0NmlJbS9Cbk5mZlVyN1YKRFlkM3pabUl3Rk9qL0gzREtIb0dpay94SzNFODJZQTJadWxWT0ZSVy96ajRBcGpQYTVPRmJwSWtkMHBtenh6ZApFY0w0NzloU0E5ZEZpeVZtU3hQdFk1emUxUCtCRTliTVUxUFNjcFJ6dzhNSEZYeHlLcVcxM1F2N0xXdzRzYmszClNjaUI3R0FDYlFpVkd6Z2t2WEc2eTg1SE91dldOdkM1R0xTaXlQOUdsUEIwVjY4dGJ4ejRKVlRSZHcvWG4vWFQKRk56UkJNM2NxOGxCT0FWdC9QQVg1K3VGY3YxUzl3RkU4WWphQmZXQ1AxamRCaWwrYzRlKzB0ZHl3VDJvSm1ZQgpCRi9rRXQxd21Hd01tSHVuTkV1UU56aDFGdEpZNTRoYlVmaVdpMzhtQVNFN3hNdE1oZmovQzRTdmFwaUROODM3CmdZYVBmczh4M0taeGJYN0MzWUFzRm5KaW5sd0FVc3MxZmRLYXI4US9ZVnM3SC9uVTRjNEl4eHh6NGY2N2ZjVnEKTTJJVEtlbnRiQ01DQXdFQUFhT0NBazR3Z2dKS01Bd0dBMVVkRXdRRk1BTUJBZjh3RGdZRFZSMFBBUUgvQkFRRApBZ0hHTUIwR0ExVWREZ1FXQkJUNlZRMk1OR1pSUTB6MzU3T25iSld2ZXVha2x6Q0J5Z1lEVlIwakJJSENNSUcvCmdCVDZWUTJNTkdaUlEwejM1N09uYkpXdmV1YWtsNkdCbTZTQm1EQ0JsVEVSTUE4R0ExVUVDaE1JUm5KbFpTQlUKVTBFeEVEQU9CZ05WQkFzVEIxSnZiM1FnUTBFeEdEQVdCZ05WQkFNVEQzZDNkeTVtY21WbGRITmhMbTl5WnpFaQpNQ0FHQ1NxR1NJYjNEUUVKQVJZVFluVnphV3hsZW1GelFHZHRZV2xzTG1OdmJURVNNQkFHQTFVRUJ4TUpWM1ZsCmNucGlkWEpuTVE4d0RRWURWUVFJRXdaQ1lYbGxjbTR4Q3pBSkJnTlZCQVlUQWtSRmdna0F3ZW1HRmcybzZZQXcKTXdZRFZSMGZCQ3d3S2pBb29DYWdKSVlpYUhSMGNEb3ZMM2QzZHk1bWNtVmxkSE5oTG05eVp5OXliMjkwWDJOaApMbU55YkRDQnp3WURWUjBnQklISE1JSEVNSUhCQmdvckJnRUVBWUh5SkFFQk1JR3lNRE1HQ0NzR0FRVUZCd0lCCkZpZG9kSFJ3T2k4dmQzZDNMbVp5WldWMGMyRXViM0puTDJaeVpXVjBjMkZmWTNCekxtaDBiV3d3TWdZSUt3WUIKQlFVSEFnRVdKbWgwZEhBNkx5OTNkM2N1Wm5KbFpYUnpZUzV2Y21jdlpuSmxaWFJ6WVY5amNITXVjR1JtTUVjRwpDQ3NHQVFVRkJ3SUNNRHNhT1VaeVpXVlVVMEVnZEhKMWMzUmxaQ0IwYVcxbGMzUmhiWEJwYm1jZ1UyOW1kSGRoCmNtVWdZWE1nWVNCVFpYSjJhV05sSUNoVFlXRlRLVEEzQmdnckJnRUZCUWNCQVFRck1Da3dKd1lJS3dZQkJRVUgKTUFHR0cyaDBkSEE2THk5M2QzY3VabkpsWlhSellTNXZjbWM2TWpVMk1EQU5CZ2txaGtpRzl3MEJBUTBGQUFPQwpBZ0VBYUs5K3Y1T0ZZdTlNNnp0WUMrTDY5c3cxb21keWxpODlsWkFmcFdNTWg5Q1JtSmhNNktCcU0vaXB3b0x0Cm54eXhHc2JDUGhjUWp1VHZ6bSt5bE42VndUTW1JbFZ5VlNMS1laY2RTanQvZUNVTis0MUs3c0Q3R1ZteFpCQUYKSUxuQkRtVEdKbUxrclUwS3V1SXBqOGxJL0U2WjZObm11UDIrUkFRU0hzZkJRaTZzc3NuWE1vNEhPVzVndFBPNwpnRHJVcFZYSUQrKzFQNFhuZGtvS243U3Z3NW4welM5ZnYxaHhCY1lJSFBQUVV6ZTJ1MzBiQVF0MG4waUl5Ukx6CmFXdWh0cEF0ZDdmZndFYkFTZ3pCN0UrTkdGNHRwVjM3ZThLaUEyeGlHU1JxVDVuZHUyOGZncE9ZODdnRDNBcloKRGN0WnZ2VENmSGRBUzVrRU8zZ25HR2VaRVZMRG1mRXN2OFRHSmEzQWxqVmE1RTQwSVFEc1VYcFFMaThHK1VDNAoxRFdadThFVlQ0cm5ZYUN3MVZYN1NoT1IxUE5DQ3ZqYjhTOHRmZHVkZDl6aFUzZ0VCMHJ4ZGVUeTF0VmJOTFhXCjk5eTkweGN3cjFaSURVd00veFEvbm9POEZSaG0wTG9QQzczRWYrSjRaQmRydld3YXVGM3pKZTMzZDRpYnhFY2IKOC9wejVXekZrZWl4WU0ybnNIaHFIc0JLdzdKUG91S05YUm5sNUlBRTFlRm1xRHlDN0cvVlQ3T0Y2Njl4TTZoYgpVdDVHMjFKRTRjTks2Tk51Y1MrZnpnMUpQWDArM1Zoc1laamo3RDV1bGpSdlFYcko4aUhnci9NNmoyb0xIdlRBCkkyTUxkcTJxalpGRE9DWHN4QnhKcGJtTEdCeDlvdzZaZXJsVXh6d3MyQVd2MnBrPQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg=="
      }
    }
  }
","payloadType":"https://witness.testifysec.com/policy/v0.1","signatures":[{"keyid":"6516d0812cb5a0d01f7f014f88e04c5d4c2d89a64e788a12950ba950fb43ef45","sig":"AhcdG55mzo5qrYnmV869QoEPdal4HPpsvafSjPbwnoA+c21PP4S6/3PaSivDqCoVnxqG+K0mbSeVrbUqdnVKYVQIY5/2PkD2NpVWciPMEg1wc6CO2xZn0VEtSF5bJkuOzQajSEjCz1jJWm8uOcCLjxogyWgLuWjfUDTYJYa945Xwq5u4MrE6WUoEZFD+YHioxCir7ZGFUp1ubnq6N+24jH7W0SpVtn/In1XwbC2Q/BEw8owWLe8lDeOoyEapNnkWl6nNiGUnnOWB1ObgGrrm21vL3kb1uugD5YcY0VUYaOSXhgEmlJdsmX76fMHRQg07XMbGY1h1iJoo+S8Z363dZw=="}]} diff --git a/policy.json b/policy.json index 20f8771..048e981 100644 --- a/policy.json +++ b/policy.json @@ -42,10 +42,10 @@ ], "extensions": { "issuer": "https://token.actions.githubusercontent.com", - "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e", "source_repository_uri": "https://github.com/testifysec/swf", - "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa", - "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e", + "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow", + "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c", + "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa", "runner_environment": "github-hosted" } } @@ -90,7 +90,15 @@ ], "roots": [ "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159" - ] + ], + "extensions": { + "issuer": "https://token.actions.githubusercontent.com", + "source_repository_uri": "https://github.com/testifysec/swf", + "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow", + "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c", + "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa", + "runner_environment": "github-hosted" + } } } ] @@ -142,10 +150,10 @@ ], "extensions": { "issuer": "https://token.actions.githubusercontent.com", - "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e", "source_repository_uri": "https://github.com/testifysec/swf", - "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa", - "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e", + "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow", + "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c", + "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa", "runner_environment": "github-hosted" } } @@ -193,10 +201,10 @@ ], "extensions": { "issuer": "https://token.actions.githubusercontent.com", - "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e", "source_repository_uri": "https://github.com/testifysec/swf", - "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa", - "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e", + "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow", + "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c", + "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa", "runner_environment": "github-hosted" } } @@ -244,10 +252,10 @@ ], "extensions": { "issuer": "https://token.actions.githubusercontent.com", - "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e", "source_repository_uri": "https://github.com/testifysec/swf", - "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa", - "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e", + "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow", + "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c", + "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa", "runner_environment": "github-hosted" } } @@ -298,10 +306,10 @@ ], "extensions": { "issuer": "https://token.actions.githubusercontent.com", - "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e", "source_repository_uri": "https://github.com/testifysec/swf", - "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa", - "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e", + "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow", + "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c", + "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa", "runner_environment": "github-hosted" } } @@ -352,10 +360,10 @@ ], "extensions": { "issuer": "https://token.actions.githubusercontent.com", - "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e", "source_repository_uri": "https://github.com/testifysec/swf", - "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa", - "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e", + "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow", + "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c", + "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa", "runner_environment": "github-hosted" } } @@ -403,61 +411,10 @@ ], "extensions": { "issuer": "https://token.actions.githubusercontent.com", - "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e", - "source_repository_uri": "https://github.com/testifysec/swf", - "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa", - "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e", - "runner_environment": "github-hosted" - } - } - } - ] - }, - "cve-scan": { - "name": "cve-scan", - "attestations": [ - { - "type": "https://witness.dev/attestations/environment/v0.1" - }, - { - "type": "https://witness.dev/attestations/git/v0.1" - }, - { - "type": "https://witness.dev/attestations/material/v0.1" - }, - { - "type": "https://witness.dev/attestations/command-run/v0.1" - }, - { - "type": "https://witness.dev/attestations/product/v0.1" - } - ], - "functionaries": [ - { - "type": "root", - "certConstraint": { - "commonname": "*", - "dnsnames": [ - "*" - ], - "emails": [ - "*" - ], - "organizations": [ - "*" - ], - "uris": [ - "*" - ], - "roots": [ - "dcf166eebe7cbd9760947a88213d94e656349c647d439569dc76a275f05b7159" - ], - "extensions": { - "issuer": "https://token.actions.githubusercontent.com", - "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e", "source_repository_uri": "https://github.com/testifysec/swf", - "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa", - "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e", + "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow", + "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c", + "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa", "runner_environment": "github-hosted" } } @@ -505,10 +462,10 @@ ], "extensions": { "issuer": "https://token.actions.githubusercontent.com", - "github_workflow_sha": "39f80b4c173e7b023a19d2aeac2686733c67b38e", "source_repository_uri": "https://github.com/testifysec/swf", - "build_signer_uri": "https://github.com/testifysec/swf/.github/workflows/witness.yml@refs/heads/slsa", - "build_signer_digest": "39f80b4c173e7b023a19d2aeac2686733c67b38e", + "build_signer_uri": "https://github.com/testifysec/witness-run-action/.github/workflows/witness.yml@refs/heads/reusable-workflow", + "build_signer_digest": "d66f89ec8539398ed9904d1a622bd0303bfe384c", + "build_config_uri": "https://github.com/testifysec/swf/.github/workflows/pipeline.yml@refs/heads/slsa", "runner_environment": "github-hosted" } }