Skip to content

Commit

Permalink
publish-release: use trusted publishers approach
Browse files Browse the repository at this point in the history
  • Loading branch information
m4rc1e committed Jan 5, 2024
1 parent f16ee65 commit 196dba6
Showing 1 changed file with 35 additions and 10 deletions.
45 changes: 35 additions & 10 deletions .github/workflows/publish-release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -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:
Expand All @@ -23,7 +22,8 @@ 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
run: |
Expand All @@ -34,6 +34,7 @@ jobs:
git fetch --tags --force
TAG_NAME=${GITHUB_REF/refs\/tags\//}
echo "$(git tag -l --format='%(contents)' $TAG_NAME)" > "${{ runner.temp }}/CHANGELOG.md"
- name: Create GitHub release
id: create_release
uses: actions/create-release@v1
Expand All @@ -46,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/gflanguages*
- 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/gflanguages
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/[email protected]
with:
# repository-url: https://test.pypi.org/legacy/ # for testing purposes
verify-metadata: false # twine previously didn't verify metadata when uploading

0 comments on commit 196dba6

Please sign in to comment.