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

SEC-1473 Allow no Truststore password #206

Open
wants to merge 3 commits into
base: 5.5.x
Choose a base branch
from
Open

Conversation

WanderingStar
Copy link

If the Keystore is loaded without a password (with the password argument null), the integrity check is skipped. (see: https://docs.oracle.com/javase/8/docs/api/java/security/KeyStore.html#load-java.io.InputStream-char:A-). Kafka handles this by giving the corresponding parameter a null default: https://github.com/confluentinc/ce-kafka/blob/master/clients/src/main/java/org/apache/kafka/common/config/SslConfigs.java#L163 But rest-utils was using "" for the default, which doesn't skip the integrity check.

This also fixes what seems like a long-existing error in the tests where the wrong number of arguments was supplied (see first commit).

@ghost
Copy link

ghost commented Oct 13, 2020

@confluentinc It looks like @WanderingStar just signed our Contributor License Agreement. 👍

Always at your service,

clabot

@@ -602,7 +602,9 @@ public void join() throws InterruptedException {
* @throws Exception If the application fails to stop
*/
public void stop() throws Exception {
server.stop();
if (server != null) {
Copy link
Author

Choose a reason for hiding this comment

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

This might be the case if there was an exception thrown during start() and we stop() in a finally block... as we do in the tests.

@@ -130,7 +130,7 @@ private static void createKeystoreWithCert(File file, String alias, Map<String,
final X509Certificate cert = new CertificateBuilder(30, "SHA1withRSA")
.sanDnsNames("localhost").generate("CN=mymachine.local, O=A client", keypair);

TestSslUtils.createKeyStore(file.getPath(), new Password(SSL_PASSWORD), alias,
TestSslUtils.createKeyStore(file.getPath(), new Password(SSL_PASSWORD), new Password(SSL_PASSWORD), alias,
Copy link
Author

Choose a reason for hiding this comment

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

This confuses me. It seems like createKeyStore's signature has been stable since 2015, but there have been changes to these tests more recently than that. How could the tests have passed?

Copy link
Member

Choose a reason for hiding this comment

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

FYI, although this method has been stable, the previously called method now no longer exists, hence the compile failure. This just bit MDS as well.

@WanderingStar WanderingStar changed the base branch from master to 5.5.x October 13, 2020 21:19
@milosimpson
Copy link
Contributor

Given that this issue was identified in an MDS deployment, there should be a test in MDS repo for confluent.metadata.server.ssl.truststore with no key yes?

@WanderingStar
Copy link
Author

We should verify that this fix actually fixes the observed problem, but is it reasonable to test your dependencies on an ongoing basis?

- 1 don't have a single static thread pool that all FileWatchers use
   - 2 update tests to cleanup temp/test keystore files

Also, introduced awaitility test library
@milosimpson
Copy link
Contributor

milosimpson commented Oct 22, 2020

We should verify that this fix actually fixes the observed problem, but is it reasonable to test your dependencies on an ongoing basis?

Yeah, I was just pointing out there "royal we" should also verify/add a test for this in MDS repo before ticket is closed, yes?

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