-
Notifications
You must be signed in to change notification settings - Fork 127
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
[JENKINS-46795] Abort builds with untrusted Jenkinsfile
, but only given passive cause
#220
base: master
Are you sure you want to change the base?
Conversation
This reverts commit f3774c3.
…iven passive cause
…rong with the build, we just did not even really try it
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
as per the jira
It should override checkTrusted(GitHubSCMSourceRequest, PullRequestSCMRevision) to check the GitHub API to see if the current revision has been approved by a maintainer.
IIUC approval is at the PR level not the commit level.
so making this change would introduce a security issue for all existing setups where the user has not setup the github branch to dismiss approvals on push?
https://docs.github.com/en/rest/pulls/reviews?apiVersion=2022-11-28#get-a-review-for-a-pull-request is not clear on this subject.
If that is the case then this needs to be opt in and not the default behaviour.
looking at the output of hub api repos/jenkinsci/kubernetes-credentials-provider-plugin/pulls/67/reviews | jq .
the commit id that was approved is available in the API, however it is unclear if this was the commit at the time of the submission of the review or what you had open in the web browser..
Additionally - wouldn;t this need some improvement in in github-branch source
(I am a bit confused - the PR looks ok - but does not as far as I can see seem to address the referenced Jira?
UPDATE: so this code does not "trust PR revisions when approved" which is what the Jira title is. That is confusing and should be changed (ideally this should be rebased to reference a new Jira to be more explicit) - as the desired Jira is still relevant.
What this does is not fail the build if the file is not trusted but only in a few special cases. (branch indexing, pushing, cron or scm trigger).
The previous code just logged a warning and continued - so nothing bad is introduced here, but I am not so sure about not trusting causes based on a denylist rather than an include list (esp give Jenkins' extensibility?).
src/main/java/org/jenkinsci/plugins/workflow/multibranch/SCMBinder.java
Outdated
Show resolved
Hide resolved
Right, the original proposal in the Jira description would have required changes to every branch source with a notion of an untrusted change request, and furthermore would have required expanded webhooks since Jenkins would need to listen to the PR being approved after it had already rejected the attempt to build the commit the first time, and would not anyway offer repository owners as much flexibility since they might wish to see CI results without necessarily approving the PR for final merge. (OTOH it would allow triggering CI without App authn or a Jenkins login.) |
In my experience it is the former—which is potentially unsafe. |
Putting into draft while I investigate options. |
Tested interactively:
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Since this relaxes security to support the use case of Jenkinsfile
contributions from untrusted contributors, I strongly recommend this be accompanied by end-user documentation. Ideally there'd be a place in the UI for that, but I'm not sure where that would be, except perhaps wordier log messages when not trusting, to point out that manual re-builds would result in trust.
@@ -165,22 +167,4 @@ public SCMBinder(String scriptPath) { | |||
|
|||
} | |||
|
|||
// TODO seems there is no general-purpose ConsoleNote which simply wraps markup in specified HTML | |||
@SuppressWarnings("rawtypes") | |||
public static class WarningNote extends ConsoleNote { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@Restricted(NoExternalUse.class)
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I do not see why; it was not used elsewhere to begin with.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nvm, misread the diff since I didn't expect removal here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That said, removing this class might cause trouble with old build logs containing non-deserializable annotations? Or is this going somewhere else? Or have you tested it and it'll just silently drop them in build logs nobody cares about anyway given the early abort?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
https://github.com/jenkinsci/jenkins/blob/aa83562568b44aa85ff17bdfab831bbe39c2fd15/core/src/main/java/hudson/console/ConsoleAnnotationOutputStream.java#L112-L125 should just drop the annotation, i.e. make the text be plain rather than yellow. Not specifically tested.
jenkinsci/scm-api-plugin@f6ec0d0 should help some. I agree that this sort of thing deserves more formal documentation, though. Can think about suitable spots in the GUI, and/or jenkins.io/doc. |
Given e.g. occasional infra hiccups necessitating rebuilds of projects for reasons outside the actual code and build script, would it make sense (or even be feasible) to limit elevating trust to situations when the previous build failed because of this lack of trust? Or would that overcomplicate things? Thinking of cases when an admin notices an infra problem (potentially even their fault) and then checks recent builds, triggering rebuilds of any that had failed, to least inconvenience the developers. That would be something we'd need to discourage with the current implementation. Perhaps we could make this at least explicit, e.g. with |
🤔 could be possible with a custom Integration of |
Here's an idea for re-building from the Jenkins UI: How about an
Does GitHub support multiple different "Re-run" gestures, with different behavior, and to what extent can the rejection of the |
Yes, that would be helpful for users of the classic log display.
Right, basically the
that I implied in #220 (comment).
No. You can attach “actions” to a check but these have a completely different UX. IIRC you cannot even control whether Re-run is displayed; if a check fails, the link is shown, and if clicked, sends an event which the App can respond to or not.
It has to be displayed as a “failure” (unfortunately the “cancelled” conclusion does not offer Re-run), but the associated text can say whatever you want. Would require some hacking around in |
👍
Would it be a viable step forward to proceed with support for Jenkins UI only for now, if the state of |
I do not think so. At least, it would make this feature useless for ci.jenkins.io, since most repository maintainers lack Job/Build permissions on the server.
IMO just making Re-run be considered trusted, as is already done upstream, suffices. This would be unrelated to the concern you raised in #220 (comment). |
Right. Re-run is less prone to admin accidents than Build Now, although complex PRs might still manage to trick reviewers into assuming flakiness when it's actually lack of trust. I do not object to going ahead with trust in Re-Run, though IMO it would be very useful to be able to use this functionality from within Jenkins as well. |
JENKINS-46795 amending #69. Downstream of jenkinsci/scm-api-plugin#180.
Note that some much less common Jenkins features use
getTrustedRevision
and would not pick up this logic: https://github.com/jenkinsci/pipeline-groovy-lib-plugin/blob/b44ce045b582f60e5b76d4a9c4cbf52dfa4184de/src/main/java/org/jenkinsci/plugins/workflow/libs/MultibranchScmRevisionVerifier.java#L62 and https://github.com/jenkinsci/basic-branch-build-strategies-plugin/blob/a76ef8f7fcb9ee0c97b9f8408c1c11e0acd29154/src/main/java/jenkins/branch/buildstrategies/basic/ChangeRequestBuildStrategyImpl.java#L138