Skip to content
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 CI work even for external contributors #377

Open
benoit74 opened this issue Nov 25, 2024 · 13 comments
Open

Make CI work even for external contributors #377

benoit74 opened this issue Nov 25, 2024 · 13 comments
Milestone

Comments

@benoit74
Copy link
Collaborator

Due to Github good security guardrails, many secrets are not passed properly when an external contributor opens a PR from its own clone. This is made for security concern. I'm not sure how we can adapt to this without breaking security, but we need to find a solution for external contributors PRs to still pass.

See https://github.com/openzim/youtube/actions/runs/12014257728

@kelson42
Copy link
Contributor

kelson42 commented Nov 25, 2024

The approach should be that each PR by an external contributor is authorised manually by people from the "Lieutenants team" https://github.com/orgs/openzim/teams/lieutenants to run the CI.

Current situation is not really a bug, but a feature: we don't want to run blindly external PR against our CI.

@benoit74
Copy link
Collaborator Author

benoit74 commented Nov 25, 2024

No, current approach (the one in place or the one you suggest are mostly identical) does not work properly, secrets are not passed to the runner when a workflow is triggered from a forked repository ; see https://docs.github.com/en/actions/security-for-github-actions/security-guides/using-secrets-in-github-actions#using-secrets-in-a-workflow

This is why codecov uploads are often failing in PRs from external contributors, and why youtube CI is systematically failing because we need access to one Youtube API key for running integration tests

@kelson42
Copy link
Contributor

@benoit74 In which repo it fails to run properly?

Actually i believe to know there is at least one which works fine... but I don't remember where is this implemented exactly.

@benoit74
Copy link
Collaborator Author

This repo is not working properly (or more exactly the fork from #371)

@rgaudin
Copy link
Member

rgaudin commented Nov 26, 2024

secrets are not passed to the runner when a workflow is triggered from a forked repository

What are you validating for if there's no secrets passing? The GH-correct way to do this when there are secrets involved are to put the required secrets in an Environment secrets ; make the CI use that environment when run from an external contributor and require approval in this case.

That's what we do for apple. Works fine.

@benoit74
Copy link
Collaborator Author

What are you validating for if there's no secrets passing?

Secrets are needed by the CI job, configured in the definition, but Github does not pass the secrets with the PR is from an external contributor.

I don't get why Environment secrets would be passed to the job, they are still secrets... Let's give it a try.

@benoit74
Copy link
Collaborator Author

I think that what make it work on kiwix-apple is not the environment but the fact that pull_request_target event is used instead of pull_request. I'm not an expert on this at all, but it looks like Github strongly recommend to be very cautious with pull_request_target: https://docs.github.com/en/actions/writing-workflows/choosing-when-your-workflow-runs/events-that-trigger-workflows#pull_request_target

@rgaudin
Copy link
Member

rgaudin commented Nov 26, 2024

Of course it is. That's why every run that involve secrets have to be manually authorized by someone (a lieutenant in apple's case) because it's strictly not possible to provide secrets to a workflow in a way that it cant be revealed by a malicious or accidental way.

The best solution is always to not use secrets in workflow.

@benoit74
Copy link
Collaborator Author

benoit74 commented Nov 26, 2024

Of course.

But then I don't get why we did not deployed this on all repos, since they (mostly all) use the CODECOV_TOKEN secret, and not having this secret is probably the cause of all instabilities we observed on these codecov actions (the action work "randomly" when CODECOV_TOKEN is not set). Are we ok that we need to generalize kiwix-apple approach based on pull_request_target on all our repos (and in particular in python bootstrap: https://github.com/openzim/_python-bootstrap/blob/main/.github/workflows/Tests.yaml)?

@rgaudin
Copy link
Member

rgaudin commented Nov 27, 2024

It was implemented last year only. Apple is different to scrapers in that secrets are very sensitive (compared to say CODECOV_TOKEN) and we had frequent external contributors.

I don't know if/how it's implemented in the repos I dont interact much with (mwoffliner, libzim/kiwix, kiwix-desktop and kiwix-tools).

On scrapers, if the only concern is the codecov_token, it might be worth investigating it directly. It is supposed to work reliably (and it did in the past) without the secret. Maybe we need to do something else to fix it without getting into this cumbersome validation just to get a coverage feedback.

@benoit74
Copy link
Collaborator Author

codecov_token is not the only concern on scrapers, but is is indeed the main one in most cases. For youtube, we also have an API_KEY secret for Youtube) which is way more sensitive.

AFAIK, codecov action is not working reliably without the codecov token due to rate limiting, see e.g. https://github.com/openzim/ted/actions/runs/11307130547/job/31499018798 at codecov ; this was with action v3, maybe this concern is now gone with v5, it looks like we now even have an new option for tokenless upload: https://github.com/codecov/codecov-action). Worth investigating indeed

@kelson42
Copy link
Contributor

@benoit74 @rgaudin I would recommed a dedicated meeting here.

@benoit74
Copy link
Collaborator Author

Not worth it until we've investigated codecov behavior with v5 action to clarify how "mandatory" the CODECOV_TOKEN is for this action.

And so far I feel like we are quite aligned with rgaudin, there is discussion but only moving forward for now. Do you mean you would like to discuss this in a meeting with us?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants