Skip to content

Commit 8402eaf

Browse files
committed
feat: publish Docker referrers and Cosign attestations for SBOM and provenance
1 parent 5db2642 commit 8402eaf

File tree

3 files changed

+110
-6
lines changed

3 files changed

+110
-6
lines changed

.github/workflows/release.yml

Lines changed: 103 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -125,3 +125,106 @@ jobs:
125125
COSIGN_EXPERIMENTAL: "1"
126126
run: |
127127
cosign sign --yes docker.io/fontebasso/php-nginx@${{ steps.push.outputs.digest }}
128+
129+
generate-sbom:
130+
name: Generate SBOM
131+
needs: merge-multiarch
132+
runs-on: ubuntu-latest
133+
steps:
134+
- name: Install Syft
135+
uses: anchore/sbom-action@v0
136+
with:
137+
image: fontebasso/php-nginx@${{ needs.merge-multiarch.outputs.digest }}
138+
format: spdx-json
139+
output-file: sbom.spdx.json
140+
registry-username: ${{ secrets.DOCKERHUB_USERNAME }}
141+
registry-password: ${{ secrets.DOCKERHUB_TOKEN }}
142+
143+
- name: Upload SBOM
144+
uses: actions/upload-artifact@v4
145+
with:
146+
name: sbom.spdx.json
147+
path: sbom.spdx.json
148+
149+
attest-sbom:
150+
name: Attest SBOM
151+
needs: [merge-multiarch, generate-sbom]
152+
runs-on: ubuntu-latest
153+
steps:
154+
- name: Log in to Docker Hub
155+
uses: docker/login-action@v3
156+
with:
157+
username: ${{ secrets.DOCKERHUB_USERNAME }}
158+
password: ${{ secrets.DOCKERHUB_TOKEN }}
159+
160+
- name: Download SBOM artifact
161+
uses: actions/download-artifact@v4
162+
with:
163+
name: sbom.spdx.json
164+
165+
- name: Install Cosign
166+
uses: sigstore/[email protected]
167+
168+
- name: Attest SBOM with Cosign (OIDC keyless)
169+
env:
170+
COSIGN_EXPERIMENTAL: "1"
171+
run: |
172+
cosign attest --yes \
173+
--predicate sbom.spdx.json \
174+
--type https://spdx.dev/Document \
175+
docker.io/fontebasso/php-nginx:${{ needs.merge-multiarch.outputs.digest }}
176+
177+
generate-provenance:
178+
name: Generate SLSA Provenance
179+
needs: merge-multiarch
180+
if: startsWith(github.ref, 'refs/tags/')
181+
uses: slsa-framework/slsa-github-generator/.github/workflows/[email protected]
182+
with:
183+
image: docker.io/fontebasso/php-nginx
184+
digest: ${{ needs.merge-multiarch.outputs.digest }}
185+
secrets:
186+
registry-username: ${{ secrets.DOCKERHUB_USERNAME }}
187+
registry-password: ${{ secrets.DOCKERHUB_TOKEN }}
188+
permissions:
189+
id-token: write
190+
contents: read
191+
packages: write
192+
actions: read
193+
194+
release:
195+
needs: [attest-sbom, generate-provenance]
196+
runs-on: ubuntu-latest
197+
steps:
198+
- name: Download SBOM artifact
199+
uses: actions/download-artifact@v4
200+
with:
201+
name: sbom.spdx.json
202+
203+
- name: Install Cosign
204+
uses: sigstore/[email protected]
205+
206+
- name: Download Provenance attestation
207+
run: |
208+
cosign download attestation \
209+
docker.io/fontebasso/php-nginx@${{ needs.merge-multiarch.outputs.digest }} \
210+
--output-file provenance.intoto.jsonl
211+
212+
- name: Generate checksum.txt
213+
run: |
214+
sha256sum sbom.spdx.json provenance.intoto.jsonl > checksum.txt
215+
216+
- name: Sign checksum.txt with Cosign (OIDC keyless)
217+
env:
218+
COSIGN_EXPERIMENTAL: "1"
219+
run: |
220+
cosign sign-blob --yes --output-signature checksum.txt.sig checksum.txt
221+
222+
- name: Upload Provenance, SBOM, and Checksum (signed) to Release
223+
uses: softprops/action-gh-release@v2
224+
with:
225+
files: |
226+
sbom.spdx.json
227+
provenance.intoto.jsonl
228+
checksum.txt
229+
checksum.txt.sig
230+
continue-on-error: false

Dockerfile

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -142,12 +142,12 @@ RUN set -eux; \
142142
ln -s /opt/php/bin/phpize /usr/bin/phpize; \
143143
ln -s /opt/php/bin/php-config /usr/bin/php-config; \
144144
mkdir -p /opt/php/etc/php/conf.d; \
145-
printf "\n" | /opt/php/bin/pecl install grpc; \
146-
echo "extension=grpc.so" > /opt/php/etc/php/conf.d/php-02-grpc.ini; \
147-
rm -rf /opt/php/bin/pecl /opt/php/bin/pear /opt/php/bin/peardev /opt/php/bin/peclcmd.php /opt/php/bin/pearcmd.php /opt/php/bin/phar /opt/php/bin/phar.phar; \
148-
find /opt/php -type f -name "peclcmd.php" -delete; \
149-
find /opt/php -type f -name "pearcmd.php" -delete; \
150-
find /opt/php -type d -name "pear" -exec rm -rf {} +; \
145+
#printf "\n" | /opt/php/bin/pecl install grpc; \
146+
#echo "extension=grpc.so" > /opt/php/etc/php/conf.d/php-02-grpc.ini; \
147+
#rm -rf /opt/php/bin/pecl /opt/php/bin/pear /opt/php/bin/peardev /opt/php/bin/peclcmd.php /opt/php/bin/pearcmd.php /opt/php/bin/phar /opt/php/bin/phar.phar; \
148+
#find /opt/php -type f -name "peclcmd.php" -delete; \
149+
#find /opt/php -type f -name "pearcmd.php" -delete; \
150+
#find /opt/php -type d -name "pear" -exec rm -rf {} +; \
151151
apk del .build-php-deps; \
152152
rm -rf /tmp/php*
153153

provenance.intoto.jsonl

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"index.docker.io/fontebasso/php-nginx","digest":{"sha256":"172b4099efe5133aa45ce8758713661006c4192c9034a343267ee4ed6521ac79"}}],"predicate":{"builder":{"id":"https://github.com/slsa-framework/slsa-github-generator/.github/workflows/generator_container_slsa3.yml@refs/tags/v2.1.0"},"buildType":"https://github.com/slsa-framework/slsa-github-generator/container@v1","invocation":{"configSource":{"uri":"git+https://github.com/fontebasso/docker-php-nginx@refs/tags/7.0.0","digest":{"sha1":"a3913e3bff9e19fd274dd75db4d4b6662f6a9363"},"entryPoint":".github/workflows/docker-image-release.yml"},"environment":{"github_actor":"fontebasso","github_actor_id":"3643096","github_base_ref":"","github_event_name":"release","github_event_payload":{"action":"published","release":{"assets":[],"assets_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/releases/214087226/assets","author":{"avatar_url":"https://avatars.githubusercontent.com/u/3643096?v=4","events_url":"https://api.github.com/users/fontebasso/events{/privacy}","followers_url":"https://api.github.com/users/fontebasso/followers","following_url":"https://api.github.com/users/fontebasso/following{/other_user}","gists_url":"https://api.github.com/users/fontebasso/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/fontebasso","id":3643096,"login":"fontebasso","node_id":"MDQ6VXNlcjM2NDMwOTY=","organizations_url":"https://api.github.com/users/fontebasso/orgs","received_events_url":"https://api.github.com/users/fontebasso/received_events","repos_url":"https://api.github.com/users/fontebasso/repos","site_admin":false,"starred_url":"https://api.github.com/users/fontebasso/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/fontebasso/subscriptions","type":"User","url":"https://api.github.com/users/fontebasso","user_view_type":"public"},"body":"## ❌ Breaking Changes\r\n\r\n- **Nginx access logs are no longer sent to stdout**, improving container cleanliness. If you relied on access logs in your orchestrator, please adapt accordingly.\r\n- **The multi-arch build process now uses GitHub Actions matrix strategy**, producing separate architecture images in parallel and merging them via `buildx imagetools`.\r\n- **The final image is cryptographically signed** using [Sigstore](https://www.sigstore.dev) via GitHub OIDC — no keys or secrets required.\r\n\r\n## ✅ Highlights\r\n\r\n- **Parallel multi-arch builds** with native `ubuntu-24.04` and `ubuntu-24.04-arm` runners\r\n- **Cosign signing + provenance attestation** (SLSA format)\r\n- **Public verifiability** via [Rekor Transparency Log](https://rekor.sigstore.dev)\r\n- **Updated documentation** including README, badges, and verification instructions","created_at":"2025-04-23T02:16:38Z","draft":false,"html_url":"https://github.com/fontebasso/docker-php-nginx/releases/tag/7.0.0","id":214087226,"name":"7.0.0","node_id":"RE_kwDOFxFLl84MwrY6","prerelease":false,"published_at":"2025-04-23T02:18:24Z","tag_name":"7.0.0","tarball_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/tarball/7.0.0","target_commitish":"main","upload_url":"https://uploads.github.com/repos/fontebasso/docker-php-nginx/releases/214087226/assets{?name,label}","url":"https://api.github.com/repos/fontebasso/docker-php-nginx/releases/214087226","zipball_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/zipball/7.0.0"},"repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/assignees{/user}","blobs_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/git/blobs{/sha}","branches_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/branches{/branch}","clone_url":"https://github.com/fontebasso/docker-php-nginx.git","collaborators_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/comments{/number}","commits_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/commits{/sha}","compare_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/compare/{base}...{head}","contents_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/contents/{+path}","contributors_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/contributors","created_at":"2021-07-17T18:13:16Z","default_branch":"main","deployments_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/deployments","description":"Robust Docker image of PHP with Nginx, based on official software and supporting amd64 and arm64.","disabled":false,"downloads_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/downloads","events_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/events","fork":false,"forks":4,"forks_count":4,"forks_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/forks","full_name":"fontebasso/docker-php-nginx","git_commits_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/git/tags{/sha}","git_url":"git://github.com/fontebasso/docker-php-nginx.git","has_discussions":true,"has_downloads":true,"has_issues":true,"has_pages":false,"has_projects":false,"has_wiki":false,"homepage":"https://hub.docker.com/r/fontebasso/php-nginx","hooks_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/hooks","html_url":"https://github.com/fontebasso/docker-php-nginx","id":387009431,"is_template":false,"issue_comment_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/issues/events{/number}","issues_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/issues{/number}","keys_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/keys{/key_id}","labels_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/labels{/name}","language":"Dockerfile","languages_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/languages","license":{"key":"mit","name":"MIT License","node_id":"MDc6TGljZW5zZTEz","spdx_id":"MIT","url":"https://api.github.com/licenses/mit"},"merges_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/merges","milestones_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/milestones{/number}","mirror_url":null,"name":"docker-php-nginx","node_id":"MDEwOlJlcG9zaXRvcnkzODcwMDk0MzE=","notifications_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/3643096?v=4","events_url":"https://api.github.com/users/fontebasso/events{/privacy}","followers_url":"https://api.github.com/users/fontebasso/followers","following_url":"https://api.github.com/users/fontebasso/following{/other_user}","gists_url":"https://api.github.com/users/fontebasso/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/fontebasso","id":3643096,"login":"fontebasso","node_id":"MDQ6VXNlcjM2NDMwOTY=","organizations_url":"https://api.github.com/users/fontebasso/orgs","received_events_url":"https://api.github.com/users/fontebasso/received_events","repos_url":"https://api.github.com/users/fontebasso/repos","site_admin":false,"starred_url":"https://api.github.com/users/fontebasso/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/fontebasso/subscriptions","type":"User","url":"https://api.github.com/users/fontebasso","user_view_type":"public"},"private":false,"pulls_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/pulls{/number}","pushed_at":"2025-04-23T02:17:36Z","releases_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/releases{/id}","size":184,"ssh_url":"git@github.com:fontebasso/docker-php-nginx.git","stargazers_count":3,"stargazers_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/stargazers","statuses_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/statuses/{sha}","subscribers_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/subscribers","subscription_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/subscription","svn_url":"https://github.com/fontebasso/docker-php-nginx","tags_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/tags","teams_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/teams","topics":["docker","docker-image","nginx","php"],"trees_url":"https://api.github.com/repos/fontebasso/docker-php-nginx/git/trees{/sha}","updated_at":"2025-04-23T02:16:45Z","url":"https://api.github.com/repos/fontebasso/docker-php-nginx","visibility":"public","watchers":3,"watchers_count":3,"web_commit_signoff_required":false},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/3643096?v=4","events_url":"https://api.github.com/users/fontebasso/events{/privacy}","followers_url":"https://api.github.com/users/fontebasso/followers","following_url":"https://api.github.com/users/fontebasso/following{/other_user}","gists_url":"https://api.github.com/users/fontebasso/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/fontebasso","id":3643096,"login":"fontebasso","node_id":"MDQ6VXNlcjM2NDMwOTY=","organizations_url":"https://api.github.com/users/fontebasso/orgs","received_events_url":"https://api.github.com/users/fontebasso/received_events","repos_url":"https://api.github.com/users/fontebasso/repos","site_admin":false,"starred_url":"https://api.github.com/users/fontebasso/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/fontebasso/subscriptions","type":"User","url":"https://api.github.com/users/fontebasso","user_view_type":"public"}},"github_head_ref":"","github_ref":"refs/tags/7.0.0","github_ref_type":"tag","github_repository_id":"387009431","github_repository_owner":"fontebasso","github_repository_owner_id":"3643096","github_run_attempt":"1","github_run_id":"14608503539","github_run_number":"13","github_sha1":"a3913e3bff9e19fd274dd75db4d4b6662f6a9363"}},"metadata":{"buildInvocationID":"14608503539-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/fontebasso/docker-php-nginx@refs/tags/7.0.0","digest":{"sha1":"a3913e3bff9e19fd274dd75db4d4b6662f6a9363"}}]}}","signatures":[{"keyid":"","sig":"MEUCIAc5QpH8RMCWPbcQqfzEW2ULeMNTgsegQGjRJPXA+Gm3AiEA9HVyjioa1Ro7bh1lDdYG8wWQ2ORrXkgvnNuzn567Z3o="}]}

0 commit comments

Comments
 (0)