Release npm package and container images #1601
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Release npm package and container images | |
on: | |
push: | |
tags: | |
- 'v*' | |
workflow_dispatch: | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: true | |
env: | |
REGISTRY: ghcr.io | |
# https://docs.github.com/en/actions/writing-workflows/choosing-what-your-workflow-does/controlling-permissions-for-github_token | |
permissions: {} | |
jobs: | |
pkg: | |
if: github.repository == 'CycloneDX/cdxgen' | |
runs-on: ubuntu-latest | |
permissions: | |
id-token: write # needed for npm provenance attestation | |
steps: | |
- uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
with: | |
persist-credentials: false | |
- name: Use Node.js | |
uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0 | |
with: | |
node-version: '24.5.0' | |
registry-url: https://registry.npmjs.org/ | |
- name: Release npm package | |
if: startsWith(github.ref, 'refs/tags/') | |
run: | | |
npm install --global corepack@latest | |
corepack enable | |
corepack pnpm install --config.strict-dep-builds=true | |
npm config set //registry.npmjs.org/:_authToken=$NODE_AUTH_TOKEN | |
echo "cyclonedx:registry=https://registry.npmjs.org" > ~/.npmrc | |
NPM_CONFIG_PROVENANCE=true corepack pnpm publish --access=public --no-git-checks | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} | |
- name: jsr publish | |
if: startsWith(github.ref, 'refs/tags/') | |
run: | | |
npx jsr publish --allow-dirty | |
continue-on-error: true | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
containers-ruby-builder-amd64: | |
if: github.repository == 'CycloneDX/cdxgen' | |
runs-on: 'ubuntu-24.04' | |
outputs: | |
image-uri: ghcr.io/cyclonedx/cdxgen-ruby-builder@${{ steps.build.outputs.digest }} | |
permissions: | |
packages: write # needed for uploading images to GH package registry | |
steps: | |
- uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
with: | |
persist-credentials: false | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@29109295f81e9208d7d86ff1c6c12d2833863392 # v3.6.0 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 | |
- name: Log in to the Container registry | |
uses: docker/login-action@184bdaa0721073962dff0199f1fb9940f07167d1 # v3.5.0 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Extract metadata (tags, labels) for Docker | |
id: meta | |
uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0 | |
with: | |
images: | | |
ghcr.io/cyclonedx/cdxgen-ruby-builder | |
flavor: latest=false,suffix=-amd64 | |
- name: Build and push Docker images | |
uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 | |
id: build | |
with: | |
context: . | |
file: ci/images/al10/Dockerfile.ruby-builder | |
platforms: linux/amd64 | |
push: true | |
tags: ${{ steps.meta.outputs.tags }} | |
labels: ${{ steps.meta.outputs.labels }} | |
- uses: cloudposse/github-action-matrix-outputs-write@ed06cf3a6bf23b8dce36d1cf0d63123885bb8375 # v1 | |
id: out | |
with: | |
outputs: |- | |
image-uri: ghcr.io/cyclonedx/cdxgen-ruby-builder@${{ steps.build.outputs.digest }} | |
containers-ruby-builder-arm64: | |
if: github.repository == 'CycloneDX/cdxgen' | |
runs-on: 'ubuntu-24.04-arm' | |
outputs: | |
image-uri: ghcr.io/cyclonedx/cdxgen-ruby-builder@${{ steps.build.outputs.digest }} | |
permissions: | |
packages: write # needed for uploading images to GH package registry | |
steps: | |
- uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
with: | |
persist-credentials: false | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@29109295f81e9208d7d86ff1c6c12d2833863392 # v3.6.0 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 | |
- name: Log in to the Container registry | |
uses: docker/login-action@184bdaa0721073962dff0199f1fb9940f07167d1 # v3.5.0 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Extract metadata (tags, labels) for Docker | |
id: meta | |
uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0 | |
with: | |
images: | | |
ghcr.io/cyclonedx/cdxgen-ruby-builder | |
flavor: latest=false,suffix=-arm64 | |
- name: Build and push Docker images | |
uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 | |
id: build | |
with: | |
context: . | |
file: ci/images/al10/Dockerfile.ruby-builder | |
platforms: linux/arm64 | |
push: true | |
tags: ${{ steps.meta.outputs.tags }} | |
labels: ${{ steps.meta.outputs.labels }} | |
- uses: cloudposse/github-action-matrix-outputs-write@ed06cf3a6bf23b8dce36d1cf0d63123885bb8375 # v1 | |
id: out | |
with: | |
outputs: |- | |
image-uri: ghcr.io/cyclonedx/cdxgen-ruby-builder@${{ steps.build.outputs.digest }} | |
containers-ruby-builder-deploy-manifest: | |
if: github.repository == 'CycloneDX/cdxgen' | |
runs-on: ubuntu-24.04 | |
needs: [ containers-ruby-builder-amd64, containers-ruby-builder-arm64 ] | |
outputs: | |
image-uri: ghcr.io/cyclonedx/cdxgen-ruby-builder@${{ steps.build.outputs.digest }} | |
permissions: | |
packages: write # needed for uploading images to GH package registry | |
steps: | |
- uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
with: | |
persist-credentials: false | |
fetch-depth: 0 | |
- uses: docker/login-action@184bdaa0721073962dff0199f1fb9940f07167d1 # v3.5.0 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0 | |
id: metadata | |
with: | |
images: ghcr.io/${{ github.repository }} | |
- uses: int128/docker-manifest-create-action@736aaa0f6ae97b2fb7f43e8dcef3ab47a02ea96e # v2.8.0 | |
id: build | |
with: | |
index-annotations: ${{ steps.metadata.outputs.labels }} | |
tags: ghcr.io/cyclonedx/cdxgen-ruby-builder:master | |
sources: | | |
${{ needs.containers-ruby-builder-amd64.outputs.image-uri }} | |
${{ needs.containers-ruby-builder-arm64.outputs.image-uri }} | |
containers: | |
if: github.repository == 'CycloneDX/cdxgen' | |
runs-on: ubuntu-latest | |
needs: [containers-ruby-builder-deploy-manifest] | |
permissions: | |
contents: write # needed for creating GH releases and uploading release assets | |
packages: write # needed for uploading images to GH package registry | |
steps: | |
- uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
with: | |
persist-credentials: false | |
- name: Use Node.js | |
uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0 | |
with: | |
node-version: '24.5.0' | |
registry-url: https://registry.npmjs.org/ | |
- uses: oras-project/setup-oras@8d34698a59f5ffe24821f0b48ab62a3de8b64b20 # v1.2.3 | |
- name: Free disk space | |
uses: jlumbroso/free-disk-space@main | |
with: | |
tool-cache: true | |
- name: Trim CI agent | |
run: | | |
chmod +x contrib/free_disk_space.sh | |
./contrib/free_disk_space.sh | |
- run: docker run --rm --privileged multiarch/qemu-user-static --reset -p yes | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 | |
- name: Log in to the Container registry | |
uses: docker/login-action@184bdaa0721073962dff0199f1fb9940f07167d1 # v3.5.0 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Extract metadata (tags, labels) for Docker | |
id: meta | |
uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0 | |
with: | |
images: | | |
ghcr.io/cyclonedx/cdxgen | |
- name: Build and push Docker images | |
uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 | |
with: | |
context: . | |
file: ci/Dockerfile | |
platforms: linux/amd64,linux/arm64 | |
push: true | |
tags: ${{ steps.meta.outputs.tags }} | |
labels: ${{ steps.meta.outputs.labels }} | |
- name: setup nydus | |
run: | | |
curl -LO https://github.com/dragonflyoss/nydus/releases/download/v2.3.1/nydus-static-v2.3.1-linux-amd64.tgz | |
tar -xvf nydus-static-v2.3.1-linux-amd64.tgz | |
chmod +x nydus-static/* | |
mv nydus-static/* /usr/local/bin/ | |
rm -rf nydus-static-v2.3.1-linux-amd64.tgz nydus-static | |
- name: nydusify | |
run: | | |
nydusify convert --oci --oci-ref --source ${{ steps.meta.outputs.tags }} --target ${{ steps.meta.outputs.tags }}-nydus --prefetch-dir /opt/cdxgen | |
nydusify check --target ${{ steps.meta.outputs.tags }}-nydus | |
if: github.ref == 'refs/heads/master' | |
continue-on-error: true | |
- name: Attach cdx sbom | |
run: | | |
corepack pnpm install --config.strict-dep-builds=true --package-import-method copy --frozen-lockfile | |
node bin/cdxgen.js -t docker -o cdxgen-oci-image.cdx.json ${{ fromJSON(steps.meta.outputs.json).tags[0] }} | |
node bin/verify.js -i cdxgen-oci-image.cdx.json --public-key contrib/bom-signer/public.key | |
oras attach --artifact-type sbom/cyclonedx ${{ fromJSON(steps.meta.outputs.json).tags[0] }} ./cdxgen-oci-image.cdx.json:application/json | |
oras discover --format tree ${{ fromJSON(steps.meta.outputs.json).tags[0] }} | |
node bin/verify.js -i ${{ fromJSON(steps.meta.outputs.json).tags[0] }} --public-key contrib/bom-signer/public.key | |
continue-on-error: true | |
env: | |
SBOM_SIGN_ALGORITHM: RS512 | |
SBOM_SIGN_PRIVATE_KEY_BASE64: ${{ secrets.SBOM_SIGN_PRIVATE_KEY }} | |
- name: Attach cdx sbom to release | |
uses: softprops/action-gh-release@72f2c25fcb47643c292f7107632f7a47c1df5cd8 # v2.3.2 | |
if: startsWith(github.ref, 'refs/tags/') | |
with: | |
files: | | |
cdxgen-oci-image.cdx.json | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
containers-secure: | |
if: github.repository == 'CycloneDX/cdxgen' | |
runs-on: ubuntu-latest | |
needs: [containers] | |
permissions: | |
contents: write # needed for creating GH releases and uploading release assets | |
packages: write # needed for uploading images to GH package registry | |
steps: | |
- uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
with: | |
persist-credentials: false | |
- name: Use Node.js | |
uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0 | |
with: | |
node-version: '24.5.0' | |
registry-url: https://registry.npmjs.org/ | |
- uses: oras-project/setup-oras@8d34698a59f5ffe24821f0b48ab62a3de8b64b20 # v1.2.3 | |
- name: Free disk space | |
uses: jlumbroso/free-disk-space@main | |
with: | |
tool-cache: true | |
- name: Trim CI agent | |
run: | | |
chmod +x contrib/free_disk_space.sh | |
./contrib/free_disk_space.sh | |
- run: docker run --rm --privileged multiarch/qemu-user-static --reset -p yes | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 | |
- name: Log in to the Container registry | |
uses: docker/login-action@184bdaa0721073962dff0199f1fb9940f07167d1 # v3.5.0 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Extract metadata (tags, labels) for Docker | |
id: meta | |
uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0 | |
with: | |
images: | | |
ghcr.io/cyclonedx/cdxgen-secure | |
- name: Build and push Docker images | |
uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 | |
with: | |
context: . | |
file: ci/Dockerfile-secure | |
platforms: linux/amd64,linux/arm64 | |
push: true | |
tags: ${{ steps.meta.outputs.tags }} | |
labels: ${{ steps.meta.outputs.labels }} | |
- name: Attach cdx sbom | |
run: | | |
corepack pnpm install --config.strict-dep-builds=true --package-import-method copy --frozen-lockfile | |
node bin/cdxgen.js -t docker -o cdxgen-secure-oci-image.cdx.json ${{ fromJSON(steps.meta.outputs.json).tags[0] }} | |
node bin/verify.js -i cdxgen-secure-oci-image.cdx.json --public-key contrib/bom-signer/public.key | |
oras attach --artifact-type sbom/cyclonedx ${{ fromJSON(steps.meta.outputs.json).tags[0] }} ./cdxgen-secure-oci-image.cdx.json:application/json | |
oras discover --format tree ${{ fromJSON(steps.meta.outputs.json).tags[0] }} | |
node bin/verify.js -i ${{ fromJSON(steps.meta.outputs.json).tags[0] }} --public-key contrib/bom-signer/public.key | |
continue-on-error: true | |
env: | |
SBOM_SIGN_ALGORITHM: RS512 | |
SBOM_SIGN_PRIVATE_KEY_BASE64: ${{ secrets.SBOM_SIGN_PRIVATE_KEY }} | |
- name: Attach cdx secure sbom to release | |
uses: softprops/action-gh-release@72f2c25fcb47643c292f7107632f7a47c1df5cd8 # v2.3.2 | |
if: startsWith(github.ref, 'refs/tags/') | |
with: | |
files: | | |
cdxgen-secure-oci-image.cdx.json | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
containers-deno: | |
if: github.repository == 'CycloneDX/cdxgen' | |
runs-on: ubuntu-latest | |
needs: [containers-ruby-builder-deploy-manifest] | |
permissions: | |
contents: write # needed for creating GH releases and uploading release assets | |
packages: write # needed for uploading images to GH package registry | |
steps: | |
- uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
with: | |
persist-credentials: false | |
- name: Use Node.js | |
uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0 | |
with: | |
node-version: '24.5.0' | |
registry-url: https://registry.npmjs.org/ | |
- uses: oras-project/setup-oras@8d34698a59f5ffe24821f0b48ab62a3de8b64b20 # v1.2.3 | |
- name: Free disk space | |
uses: jlumbroso/free-disk-space@main | |
with: | |
tool-cache: true | |
- name: Trim CI agent | |
run: | | |
chmod +x contrib/free_disk_space.sh | |
./contrib/free_disk_space.sh | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@29109295f81e9208d7d86ff1c6c12d2833863392 # v3.6.0 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 | |
- name: Log in to the Container registry | |
uses: docker/login-action@184bdaa0721073962dff0199f1fb9940f07167d1 # v3.5.0 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Extract metadata (tags, labels) for Docker | |
id: meta | |
uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0 | |
with: | |
images: | | |
ghcr.io/cyclonedx/cdxgen-deno | |
- name: Build and push Docker images | |
uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 | |
with: | |
context: . | |
file: ci/Dockerfile-deno | |
platforms: linux/amd64,linux/arm64 | |
push: true | |
tags: ${{ steps.meta.outputs.tags }} | |
labels: ${{ steps.meta.outputs.labels }} | |
- name: Attach cdx sbom | |
run: | | |
corepack pnpm install --config.strict-dep-builds=true --package-import-method copy --frozen-lockfile | |
node bin/cdxgen.js -t docker -o cdxgen-deno-oci-image.cdx.json ${{ fromJSON(steps.meta.outputs.json).tags[0] }} | |
node bin/verify.js -i cdxgen-deno-oci-image.cdx.json --public-key contrib/bom-signer/public.key | |
oras attach --artifact-type sbom/cyclonedx ${{ fromJSON(steps.meta.outputs.json).tags[0] }} ./cdxgen-deno-oci-image.cdx.json:application/json | |
oras discover --format tree ${{ fromJSON(steps.meta.outputs.json).tags[0] }} | |
node bin/verify.js -i ${{ fromJSON(steps.meta.outputs.json).tags[0] }} --public-key contrib/bom-signer/public.key | |
continue-on-error: true | |
env: | |
SBOM_SIGN_ALGORITHM: RS512 | |
SBOM_SIGN_PRIVATE_KEY_BASE64: ${{ secrets.SBOM_SIGN_PRIVATE_KEY }} | |
- name: Attach cdx deno sbom to release | |
uses: softprops/action-gh-release@72f2c25fcb47643c292f7107632f7a47c1df5cd8 # v2.3.2 | |
if: startsWith(github.ref, 'refs/tags/') | |
with: | |
files: | | |
cdxgen-deno-oci-image.cdx.json | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
containers-ppc64: | |
if: github.repository == 'CycloneDX/cdxgen' | |
runs-on: ubuntu-latest | |
permissions: | |
packages: write # needed for uploading images to GH package registry | |
steps: | |
- uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
with: | |
persist-credentials: false | |
- name: Use Node.js | |
uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0 | |
with: | |
node-version: '24.5.0' | |
registry-url: https://registry.npmjs.org/ | |
- uses: oras-project/setup-oras@8d34698a59f5ffe24821f0b48ab62a3de8b64b20 # v1.2.3 | |
- name: Free disk space | |
uses: jlumbroso/free-disk-space@main | |
with: | |
tool-cache: true | |
- name: Trim CI agent | |
run: | | |
chmod +x contrib/free_disk_space.sh | |
./contrib/free_disk_space.sh | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@29109295f81e9208d7d86ff1c6c12d2833863392 # v3.6.0 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 | |
- name: Log in to the Container registry | |
uses: docker/login-action@184bdaa0721073962dff0199f1fb9940f07167d1 # v3.5.0 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Extract metadata (tags, labels) for Docker | |
id: meta | |
uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0 | |
with: | |
images: | | |
ghcr.io/cyclonedx/cdxgen-ppc64 | |
- name: Build and push Docker images | |
uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 | |
with: | |
context: . | |
file: ci/Dockerfile-ppc64 | |
platforms: linux/ppc64le | |
push: true | |
tags: ${{ steps.meta.outputs.tags }} | |
labels: ${{ steps.meta.outputs.labels }} | |
cache-from: type=gha,scope=cdxgen-ppc64 | |
cache-to: type=gha,mode=max,scope=cdxgen-ppc64 | |
containers-bun: | |
if: github.repository == 'CycloneDX/cdxgen' | |
runs-on: ubuntu-latest | |
permissions: | |
contents: write # needed for creating GH releases and uploading release assets | |
packages: write # needed for uploading images to GH package registry | |
steps: | |
- uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
with: | |
persist-credentials: false | |
- name: Use Node.js | |
uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0 | |
with: | |
node-version: '24.5.0' | |
registry-url: https://registry.npmjs.org/ | |
- uses: oras-project/setup-oras@8d34698a59f5ffe24821f0b48ab62a3de8b64b20 # v1.2.3 | |
- name: Free disk space | |
uses: jlumbroso/free-disk-space@main | |
with: | |
tool-cache: true | |
- name: Trim CI agent | |
run: | | |
chmod +x contrib/free_disk_space.sh | |
./contrib/free_disk_space.sh | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@29109295f81e9208d7d86ff1c6c12d2833863392 # v3.6.0 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 | |
- name: Log in to the Container registry | |
uses: docker/login-action@184bdaa0721073962dff0199f1fb9940f07167d1 # v3.5.0 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Extract metadata (tags, labels) for Docker | |
id: meta | |
uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0 | |
with: | |
images: | | |
ghcr.io/cyclonedx/cdxgen-bun | |
- name: Build and push Docker images | |
uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 | |
with: | |
context: . | |
file: ci/Dockerfile-bun | |
platforms: linux/amd64,linux/arm64 | |
push: true | |
tags: ${{ steps.meta.outputs.tags }} | |
labels: ${{ steps.meta.outputs.labels }} | |
- name: Attach cdx sbom | |
run: | | |
corepack pnpm install --config.strict-dep-builds=true --package-import-method copy --frozen-lockfile | |
node bin/cdxgen.js -t docker -o cdxgen-bun-oci-image.cdx.json ${{ fromJSON(steps.meta.outputs.json).tags[0] }} | |
node bin/verify.js -i cdxgen-bun-oci-image.cdx.json --public-key contrib/bom-signer/public.key | |
oras attach --artifact-type sbom/cyclonedx ${{ fromJSON(steps.meta.outputs.json).tags[0] }} ./cdxgen-bun-oci-image.cdx.json:application/json | |
oras discover --format tree ${{ fromJSON(steps.meta.outputs.json).tags[0] }} | |
node bin/verify.js -i ${{ fromJSON(steps.meta.outputs.json).tags[0] }} --public-key contrib/bom-signer/public.key | |
continue-on-error: true | |
env: | |
SBOM_SIGN_ALGORITHM: RS512 | |
SBOM_SIGN_PRIVATE_KEY_BASE64: ${{ secrets.SBOM_SIGN_PRIVATE_KEY }} | |
- name: Attach cdx bun sbom to release | |
uses: softprops/action-gh-release@72f2c25fcb47643c292f7107632f7a47c1df5cd8 # v2.3.2 | |
if: startsWith(github.ref, 'refs/tags/') | |
with: | |
files: | | |
cdxgen-bun-oci-image.cdx.json | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |