name: Publish to PyPI on: push: tags: - "v*.*.*" jobs: publish: runs-on: ubuntu-latest permissions: id-token: write # required for OIDC trusted publishing steps: - uses: actions/checkout@v4 - name: Set up Python uses: actions/setup-python@v5 with: python-version: "3.12" cache: "pip" - name: Install build tools run: pip install build twine - name: Build distribution run: python -m build - name: Check distribution run: twine check dist/* - name: Publish to PyPI uses: pypa/gh-action-pypi-publish@release/v1