-
Notifications
You must be signed in to change notification settings - Fork 14.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Make "Trusted Publishing" works for our PyPI releasing #41937
Comments
Just to add - example changes in workflows proposed by |
@potiuk is this ready to pick? just checking. |
Yep. |
Thanks, to my understand this one to implement for all the packages that we release today? airflow, providers, airflow python client? I’m planning to implement in generalize way, so that it can be useful for other Apache projects. This would allow them to integrate their scripts if they have any custom, and run it as a GitHub Action, WDYT? :) |
Absolutely. We can start with providers - then we will have a chance to test it quickly - and then use it for the others.
Perfect. ASF infrastructure already has a repo for shared actions in ASF: https://github.com/apache/infrastructure-actions and we are just discussing to splitting it to separate actions, but the idea is to have something that will be reusable across many projects. I think the best (and most reusable) way of publishing is to use packages released in "svn". We should be able to plug in this step in the release process. And we have two different steps there:
We should just download all packages from https://dist.apache.org/repos/dist/dev/airflow/providers/pypi/
But we need to make sure that the "pypi" packages are also stored in SVN - the little difficulty is that we currently do not upload "pypi" RC packages to SVN. The "rc" candidates in SVN are different than the one we publish to PyPI, because they do not contain "rc" in the version (because potentially they might become final candidates to upload). So we should modify the process and make sure that we upload "pypi" packages to SVN (I propose to add "pypi" subfolder - so the release process shoudl be updated to clean/recreate the Then our action should be as simple as a) download the right packages from SVN b) push them to PyPI via trusted publishing. I have a feeling that this might be simply a standard xml composite action using existing actions from GitHub - nothing fancy, we might just add a few options: a) test mode - do everything except that final step will be just printing what should be done
Final packages can be directly downloaded from https://github.com/apache/airflow/blob/main/dev/README_RELEASE_PROVIDER_PACKAGES.md#publish-release-to-svn - i.e. download and push packages from https://dist.apache.org/repos/dist/release/airflow/providers/ - the packages are the same as the ones uploaded to PyPI, There - the little difficulty with it that we should know WHICH packages to upload. And this I think means that the easiest will be to do it just before this step: for file in "${SOURCE_DIR}"/*
do
base_file=$(basename ${file})
cp -v "${file}" "${AIRFLOW_REPO_ROOT}/dist/${base_file//rc[0-9]/}"
svn mv "${file}" "${base_file//rc[0-9]/}"
done
And upload them from the "dist" SVN not from the "release". Because at this moment, release manager already removed the files that were removed during voting - so "dist" contains only the packages that in a moment will be promoted to be "final" packages. But the files are still in "dev" and those are the only ones we should upload to PyPI. In "release" there will be all the previosly uploaded last version of the packages - even those we do not release now. There, likely we need some controls - for example, being able to manually override which packages we want to publish. We might start with a simple set of features, but later on that action might become a little more feature-full.
|
BTW. Speaking of licences - @Claudenw works on a new version of RAT that should allow us to verify licences without unpacking the files, so once this is released (I guess very soon) - we wil be able to use it in the GitHub Action and do the sources licence verification. Here, one of the options we will have to add is to be able to provide an extra file with "ratignore". |
Also later we might add reproducibility check - so we will be able to build the same packages locally on GitHub Actions and compare them with the ones we pulled from SVN - that would be an ultimate check for reproducibility - whether there are no MITM attacks etc. and will be ultimately a way to verify if the future platform running ATR (Apache Trusted Releases) build has not been compromised. |
Thats fantastic :) I was reviewing the current release process steps and had a few questions about the packages published to SVN versus those published to PyPI. Thanks for clarifying—it's much clearer now. The idea of a test/verification mode is excellent! |
Yeah. the main thing is that the "RC" packages we keep in SVN do not have RC in version - as they can "eventually" when voted become final packages (we just move them to "release" SVN when they BTW. This RC variation MIGHT change in the future - PyPI team has two things they are working on:
|
Alright have basic feat workflow. it will not do any publish but it checks out the packages from the svn and validates checksum and svn check. if this workflow design and approach make sense we can further extend this one. Action repo: This is usage repo: sample github action workflow: https://github.com/gopidesupavan/example-workspace/blob/main/.github/workflows/custom-action-example.yml SVN check: Checksum check: |
We already agreed with the ASF infrastrucutre that it would be great to use Trusted publishing to publish packages to PyPI. Curently we are using "twine" and local API keys by release managers - but https://docs.pypi.org/trusted-publishers/ allows to configure our PyPI organisation to accept "Github Actions" workflows publishing to PyPI via dedicated workflows - where GitHub Actions is a trusted publisher.
The documentation explains how to do it - we will need to involve INFRA to configure it for our repository.
The idea to implement is is that Github Actions workflow should not "build" the packages to publish in PyPI - but they should download them from "https://downloads.apache.org/" and "https://dist.apache.org/repos/dist/dev/airflow/" for RC/Alpha/Beta packages, verify their integrity (checksums/signatures) similarly to https://github.com/apache/airflow/blob/main/dev/README_RELEASE_AIRFLOW.md and publishing those packages.
Intead of "twine upload", release manager should just run a workflow in GitHub Actions that should download packages from apache svn/downloads and publish them in PyPI after verification.
The text was updated successfully, but these errors were encountered: