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

Introduced protections against predictable RNG abuse #3728

Closed
wants to merge 2 commits into from

Conversation

zcarroll4
Copy link

This change replaces all new instances of java.util.Random with the marginally slower, but much more secure java.security.SecureRandom.

We have to work pretty hard to get computers to generate genuinely unguessable random bits. The java.util.Random type uses a method of pseudo-random number generation that unfortunately emits fairly predictable numbers.

If the numbers it emits are predictable, then it's obviously not safe to use in cryptographic operations, file name creation, token construction, password generation, and anything else that's related to security. In fact, it may affect security even if it's not directly obvious.

Switching to a more secure version is simple and our changes all look something like this:

- Random r = new Random();
+ Random r = new java.security.SecureRandom();
More reading

Powered by: pixeebot (codemod ID: pixee:java/secure-random)

@chirlu
Copy link
Member

chirlu commented Jan 13, 2024

Is this some kind of advertisement/spam?

@buchen
Copy link
Member

buchen commented Jan 16, 2024

Is this some kind of advertisement/spam?

I'd say advertisement.

I do not think the change is relevant. It either changes tests or the random generation of new colors. I do not see it addressing any security relevant code.

@zcarroll4
Copy link
Author

Not an ad but it was generated by Pixee as we attempt to generate findings for software vulnerabilities in open source code. Though Pixeebot generated a valid suggestion from a security perspective, (as was already noted above) this situation does not require more security and the current method is more performant. It is understandable that you close the PR. Thank you for being a good sport about this.

@buchen buchen closed this Jan 20, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants