From d0d148890f30f9e0c5d988c50f5841e680712f4f Mon Sep 17 00:00:00 2001 From: Marc Foley Date: Fri, 9 Feb 2024 14:20:05 +0000 Subject: [PATCH] publish-release: update to trusted publishers workflow --- .github/workflows/publish-release.yml | 43 ++++++++++++++++++++------- 1 file changed, 33 insertions(+), 10 deletions(-) diff --git a/.github/workflows/publish-release.yml b/.github/workflows/publish-release.yml index 24eede045c..2b3c5b3c9a 100644 --- a/.github/workflows/publish-release.yml +++ b/.github/workflows/publish-release.yml @@ -7,9 +7,8 @@ name: Create and Publish Release jobs: build: - name: Create and Publish Release + name: Build distribution runs-on: ubuntu-latest - steps: - uses: actions/checkout@v2 with: @@ -23,7 +22,7 @@ jobs: - name: Install release dependencies run: | python -m pip install --upgrade pip - pip install --upgrade setuptools wheel twine + pip install --upgrade setuptools wheel build - name: Get release notes id: release_notes @@ -48,10 +47,34 @@ jobs: draft: false prerelease: false - - name: Build and publish to PyPI - env: - TWINE_USERNAME: ${{ secrets.PYPI_USERNAME }} - TWINE_PASSWORD: ${{ secrets.PYPI_PASSWORD }} - run: | - python setup.py sdist bdist_wheel - twine upload dist/glyphsets* + - name: Build a binary wheel and a source tarball + run: python3 -m build + - name: Store the distribution packages + uses: actions/upload-artifact@v3 + with: + name: python-package-distributions + path: dist/ + + publish-to-pypi: + name: >- + Publish Python 🐍 distribution 📦 to PyPI + if: startsWith(github.ref, 'refs/tags/') # only publish to PyPI on tag pushes + needs: + - build + runs-on: ubuntu-latest + environment: + name: pypi + url: https://pypi.org/p/glyphsets + permissions: + id-token: write # IMPORTANT: mandatory for trusted publishing + steps: + - name: Download all the dists + uses: actions/download-artifact@v3 + with: + name: python-package-distributions + path: dist/ + - name: Publish distribution 📦 to PyPI + uses: pypa/gh-action-pypi-publish@v1.8.11 + with: + # repository-url: https://test.pypi.org/legacy/ # for testing purposes + verify-metadata: false # twine previously didn't verify metadata when uploading \ No newline at end of file