v1.4.0 #10
Workflow file for this run
This file contains 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 | |
on: | |
release: | |
types: | |
- published | |
permissions: # added using https://github.com/step-security/secure-workflows | |
contents: read | |
jobs: | |
build: | |
name: Build artifacts | |
runs-on: ubuntu-latest | |
outputs: | |
hashes: ${{ steps.hash.outputs.hashes }} | |
steps: | |
- uses: actions/checkout@0ad4b8fadaa221de15dcec353f45205ec38ea70b # v4.1.4 | |
- uses: actions/setup-python@82c7e631bb3cdc910f68e0081d67478d79c6982d | |
with: | |
python-version: "3.x" | |
cache: "pip" | |
cache-dependency-path: pyproject.toml | |
- name: deps | |
run: python -m pip install -U build | |
- name: build | |
run: python -m build | |
- name: Generate hashes for provenance | |
shell: bash | |
id: hash | |
run: | | |
# sha256sum generates sha256 hash for all artifacts. | |
# base64 -w0 encodes to base64 and outputs on a single line. | |
# sha256sum artifact1 artifact2 ... | base64 -w0 | |
echo "hashes=$(sha256sum ./dist/* | base64 -w0)" >> $GITHUB_OUTPUT | |
- name: Upload built packages | |
uses: actions/upload-artifact@65462800fd760344b1a7b4382951275a0abb4808 # v4.3.3 | |
with: | |
name: built-packages | |
path: ./dist/ | |
if-no-files-found: warn | |
generate-provenance: | |
needs: [build] | |
name: Generate build provenance | |
permissions: | |
actions: read # To read the workflow path. | |
id-token: write # To sign the provenance. | |
contents: write # To add assets to a release. | |
# Currently this action needs to be referred by tag. More details at: | |
# https://github.com/slsa-framework/slsa-github-generator#verification-of-provenance | |
uses: slsa-framework/slsa-github-generator/.github/workflows/generator_generic_slsa3.yml@v2.0.0 | |
with: | |
provenance-name: provenance-id-${{ github.event.release.tag_name }}.intoto.jsonl | |
base64-subjects: "${{ needs.build.outputs.hashes }}" | |
upload-assets: true | |
release-pypi: | |
needs: [build, generate-provenance] | |
runs-on: ubuntu-latest | |
permissions: | |
id-token: write # To upload via OIDC. | |
steps: | |
- name: Download artifacts directories # goes to current working directory | |
uses: actions/download-artifact@65a9edc5881444af0b9093a5e628f2fe47ea3b2e # v4.1.7 | |
- name: publish | |
uses: pypa/gh-action-pypi-publish@81e9d935c883d0b210363ab89cf05f3894778450 # v1.8.14 | |
with: | |
packages-dir: built-packages/ | |
release-github: | |
needs: [build, generate-provenance] | |
runs-on: ubuntu-latest | |
permissions: | |
# Needed to upload release assets. | |
contents: write | |
# Needed to sign release assets. | |
id-token: write | |
steps: | |
- name: Download artifacts directories # goes to current working directory | |
uses: actions/download-artifact@65a9edc5881444af0b9093a5e628f2fe47ea3b2e # v4.1.7 | |
- name: Sign artifacts | |
uses: sigstore/gh-action-sigstore-python@v2.1.1 | |
with: | |
inputs: ./built-packages/*.tar.gz ./built-packages/*.whl | |
- name: Upload artifacts to GitHub | |
# Confusingly, this action also supports updating releases, not | |
# just creating them. This is what we want here, since we've manually | |
# created the release that triggered the action. | |
uses: softprops/action-gh-release@9d7c94cfd0a1f3ed45544c887983e9fa900f0564 # v2.0.4 | |
with: | |
files: | | |
built-packages/* |