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

Fix for SECURITY-2979 / CVE-2023-50771 #261

Conversation

tumbl3w33d
Copy link
Contributor

Hi, this fixes the open redirect vulnerability of #259 by validating. I've patched that for our internal use and I didn't work on the other open CVE because from my understanding it's only relevant if you enable this fallback user functionality which is not relevant for us. I thought it might still make sense to propose this here so others can quickly patch it for themselves or just use our fork release.

Please forgive me for not writing a test. I just wanted to share the fix to make the world a better place with the little time I have. Feel free to steal my code and do it properly.

Testing done

I manually tested this following these steps:

  • install vulnerable version to craft a working URL
  • this works to exploit it: https://jenkins.example.com/securityRealm/commenceLogin?from=https://google.com
  • install my patched version of the plugin
  • call the exploit URL again - result: no redirect anymore
  • the rest of the functionality seems to work fine as before, but I didn't do much more than getting logged in via oidc

Submitter checklist

Preview Give feedback

Sanitize redirect url to make sure it cannot point wherever the from query parameter shows.
Copy link

codecov bot commented Jan 30, 2024

Codecov Report

Attention: 11 lines in your changes are missing coverage. Please review.

Comparison is base (742fe57) 71.21% compared to head (11f77a7) 70.46%.
Report is 3 commits behind head on master.

❗ Current head 11f77a7 differs from pull request most recent head f4d98ec. Consider uploading reports for the commit f4d98ec to get more accurate results

Files Patch % Lines
...va/org/jenkinsci/plugins/oic/OicSecurityRealm.java 8.33% 9 Missing and 2 partials ⚠️
Additional details and impacted files
@@             Coverage Diff              @@
##             master     #261      +/-   ##
============================================
- Coverage     71.21%   70.46%   -0.75%     
  Complexity      190      190              
============================================
  Files             9        9              
  Lines           740      745       +5     
  Branches        122      124       +2     
============================================
- Hits            527      525       -2     
- Misses          153      160       +7     
  Partials         60       60              

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

}
}
// If the URL is null, empty, or invalid, return the root URL
return getRootUrl();
Copy link
Contributor

@michael-doubez michael-doubez Jan 31, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Root URL is not always correctly setup (typicallty localhost on k8s deployments) and people rely on referer to deduce the correct URL as seen by the user.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

See my comment in the issue, please. The referer is passed in when calling the function.

Copy link
Contributor

@michael-doubez michael-doubez left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please use referer if not empty.

@tumbl3w33d
Copy link
Contributor Author

Hello @michael-doubez , thank you for your feedback. The referer is already passed in when the validation method is being called. The precedence is the same as before: from wins against Referer wins against root URL (which is also the fallback for all kinds of malformed URLs).

Copy link
Contributor

@michael-doubez michael-doubez left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Right.
LGTM

@tumbl3w33d
Copy link
Contributor Author

I've added a test yet, but I cannot figure out how to determine the dynamic port of the wireMockRule. Hints appreciated. It has a constructor that accepts the rootUrl as string and I wanted to use that one but it was ignored in github ci.

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

Successfully merging this pull request may close these issues.

2 participants