Skip to content

Commit

Permalink
Merge pull request #139 from asgrim/consolidate-release-pipelines
Browse files Browse the repository at this point in the history
Use GH attestation and organise workflows better
  • Loading branch information
asgrim authored Nov 27, 2024
2 parents 3c6b6a0 + 41a9bd4 commit 8f18c18
Show file tree
Hide file tree
Showing 7 changed files with 103 additions and 94 deletions.
63 changes: 63 additions & 0 deletions .github/workflows/build-phar.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
# Invoking this pipeline requires additional permissions, so must be invoked
# in a way to pass those permissions on, e.g.:
#
# build-phar:
# permissions:
# contents: read
# id-token: write
# attestations: write
# uses: ./.github/workflows/build-phar.yml

name: "Build the PIE PHAR"

on:
workflow_call:

permissions:
contents: read

jobs:
build-phar:
runs-on: ${{ matrix.operating-system }}
strategy:
matrix:
operating-system:
- ubuntu-latest
php-versions:
- '8.1'
permissions:
# id-token:write is required for build provenance attestation.
id-token: write
# attestations:write is required for build provenance attestation.
attestations: write
steps:
- name: Setup PHP
uses: shivammathur/setup-php@v2
with:
coverage: none
tools: composer, box
php-version: "${{ matrix.php-version }}"
- uses: actions/checkout@v4
with:
fetch-depth: 0
# Ensure some kind of previous tag exists, otherwise box fails
- run: git describe --tags HEAD || git tag 0.0.0
- uses: ramsey/composer-install@v3
- name: Build PHAR
run: box compile
- name: Check the PHAR executes
run: php pie.phar --version
- name: Generate build provenance attestation
# It does not make sense to do this for PR builds, nor do contributors
# have permission to do. We can't write attestations to `php/pie` in an
# unprivileged context, otherwise anyone could send a PR with malicious
# code, which would store attestation that `php/pie` built the PHAR, and
# it would look genuine. So this should NOT run for PR builds.
if: github.event_name != 'pull_request'
uses: actions/attest-build-provenance@v1
with:
subject-path: '${{ github.workspace }}/pie.phar'
- uses: actions/upload-artifact@v4
with:
name: pie-${{ github.sha }}.phar
path: pie.phar
7 changes: 6 additions & 1 deletion .github/workflows/continuous-integration.yml
Original file line number Diff line number Diff line change
Expand Up @@ -109,4 +109,9 @@ jobs:
- unit-tests
- coding-standards
- static-analysis
uses: ./.github/workflows/release-unsigned-phar.yml
# See build-phar.yml for a list of the permissions and why they are needed
permissions:
contents: read
id-token: write
attestations: write
uses: ./.github/workflows/build-phar.yml
17 changes: 12 additions & 5 deletions .github/workflows/docs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,10 +19,14 @@ concurrency:

jobs:
build-phar:
uses: ./.github/workflows/release-unsigned-phar.yml
# See build-phar.yml for a list of the permissions and why they are needed
permissions:
contents: read
id-token: write
attestations: write
uses: ./.github/workflows/build-phar.yml

# Build job
build:
build-docs-package:
runs-on: ubuntu-latest
needs:
- build-phar
Expand All @@ -35,20 +39,23 @@ jobs:
uses: actions/download-artifact@v4
with:
name: pie-${{ github.sha }}.phar
- name: Verify the PHAR
env:
GH_TOKEN: ${{ github.token }}
run: gh attestation verify pie.phar --repo ${{ github.repository }}
- name: Copy PHAR into docs
run: cp pie.phar docs-package/pie-nightly.phar
- name: Upload artifact
uses: actions/upload-pages-artifact@v3
with:
path: docs-package

# Deployment job
deploy:
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
needs: build
needs: build-docs-package
permissions:
contents: read
# pages:write is required to deploy to GitHub pages.
Expand Down
38 changes: 0 additions & 38 deletions .github/workflows/release-unsigned-phar.yml

This file was deleted.

66 changes: 20 additions & 46 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: "Release"
name: "Publish the PHAR for Releases"

on:
release:
Expand All @@ -9,58 +9,32 @@ permissions:
contents: read

jobs:
build-phar:
# See build-phar.yml for a list of the permissions and why they are needed
permissions:
contents: read
id-token: write
attestations: write
uses: ./.github/workflows/build-phar.yml

release-phar:
runs-on: ${{ matrix.operating-system }}
strategy:
matrix:
operating-system:
- ubuntu-latest
php-versions:
- '8.1'
runs-on: ubuntu-latest
needs:
- build-phar
permissions:
# contents:write is required to upload the binaries to the release.
contents: write
# id-token:write is required for build provenance attestation.
id-token: write
# attestations:write is required for build provenance attestation.
attestations: write
steps:
- name: Setup PHP
uses: shivammathur/setup-php@v2
with:
coverage: none
tools: composer, box
php-version: "${{ matrix.php-version }}"
- uses: actions/checkout@v4
with:
fetch-depth: 0
- uses: ramsey/composer-install@v3
- name: Build PHAR
run: box compile
- name: Check the PHAR executes
run: php pie.phar --version
- name: Import GPG key
uses: crazy-max/ghaction-import-gpg@v6
with:
gpg_private_key: ${{ secrets.GPG_SIGNING_KEY }}
passphrase: ${{ secrets.GPG_SIGNING_KEY_PASSPHRASE }}
- name: Sign the PHAR
run: |
gpg --local-user asgrim+pie-releases@php.net \
--batch \
--yes \
--passphrase="${{ secrets.GPG_SIGNING_KEY_PASSPHRASE }}" \
--detach-sign \
--output pie.phar.asc \
pie.phar
- name: Generate build provenance attestation
uses: actions/attest-build-provenance@v1
- name: Fetch built PHAR from artifacts
uses: actions/download-artifact@v4
with:
subject-path: '${{ github.workspace }}/pie.phar'
name: pie-${{ github.sha }}.phar
- name: Verify the PHAR
env:
GH_TOKEN: ${{ github.token }}
run: gh attestation verify pie.phar --repo ${{ github.repository }}
- name: Upload binaries to release
uses: softprops/action-gh-release@v2
if: ${{startsWith(github.ref, 'refs/tags/') }}
with:
files: |
pie.phar
pie.phar.asc
files: pie.phar
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ please read [extension-maintainers](./docs/extension-maintainers.md).
- Download `pie.phar` either:
- [latest stable release](https://github.com/php/pie/releases)
- [latest unstable nightly](https://php.github.io/pie/pie-nightly.phar)
- Validate the signature in `pie.phar.asc`
- Verify the PHAR's source with `gh attestation verify pie.phar --repo php/pie`
- You may then invoke PIE with `php pie.phar <command>`

Further installation details can be found in the [usage](./docs/usage.md) docs.
Expand Down
4 changes: 1 addition & 3 deletions docs/usage.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,7 @@ order: 2
### Manual installation

- Download `pie.phar` from the [latest releases](https://github.com/php/pie/releases)
- Validate the signature in `pie.phar.asc`
- You can fetch the public key with `gpg --recv-key 343F8427AD6B48FF`
- Then you can verify the release with `gpg --verify pie.phar.asc pie.phar`
- Verify the PHAR's source with `gh attestation verify pie.phar --repo php/pie`
- You may then invoke PIE with `php pie.phar <command>`
- Optionally, copy `pie.phar` into your `$PATH`, e.g. `cp pie.phar /usr/local/bin/pie`
- If you copy PIE into your `$PATH`, you may then invoke PIE with `pie <command>`
Expand Down

0 comments on commit 8f18c18

Please sign in to comment.