Skip to content

Commit

Permalink
Use trusted publisher and environment (#278)
Browse files Browse the repository at this point in the history
* Use trusted publisher and environment

Setup PyPi for datatrails-python to use a trusted publisher. Delete
any API tokens in PyPi for datatrails-python.

In github repo delete PYPI secrets and create an environmant called
release that is restricted to the main branch.
  • Loading branch information
eccles authored Nov 29, 2024
1 parent 290578c commit f626140
Showing 1 changed file with 24 additions and 9 deletions.
33 changes: 24 additions & 9 deletions .github/workflows/package.yml
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
# This workflow will upload a Python Package using Twine when a release is created
# For more information see: https://help.github.com/en/actions/language-and-framework-guides/using-python-with-github-actions#publishing-to-package-registries
# This workflow will upload a Python Package using a release environment and a trusted publisher.
# See PyPi management in the datatrails confluence service for an explanation.
#
# Create a trusted publisher for datatrails-python in pypi.org and delete any API tokens.
# In github add an environment called release that is restricted to the main branch and
# delete any PYPI secrets.

name: Package and Publish

Expand All @@ -9,15 +13,19 @@ on:

jobs:
deploy:
environment: release
permissions:
id-token: write # This is required for requesting the JWT
contents: read # This is required for actions/checkout

runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.x'

- name: Install dependencies
run: |
export DEBIAN_FRONTEND=noninteractive
Expand All @@ -37,21 +45,28 @@ jobs:
python3 -m pip install --upgrade pip
python3 -m pip install -r requirements-dev.txt
python3 -m pip install setuptools wheel
- name: Build and publish
env:
TWINE_USERNAME: ${{ secrets.PYPI_USERNAME }}
TWINE_PASSWORD: ${{ secrets.PYPI_PASSWORD }}
shell: bash

- name: Create wheel
run: |
rm -f archivist/about.py
./scripts/version.sh
python3 -m build --sdist
python3 -m build --wheel
twine check dist/*
twine upload dist/*
shell: bash

- name: Publish to PyPi
uses: pypa/gh-action-pypi-publish@release/v1
with:
verbose: true
attestations: true

- name: Build docs
run: |
./scripts/zipnotebooks.sh
(cd docs && make clean && make html)
shell: bash

- name: Publish docs
uses: peaceiris/actions-gh-pages@v3
with:
Expand Down

0 comments on commit f626140

Please sign in to comment.