Skip to content

Commit ee2b249

Browse files
silmebsideup
andauthored
Support for client certificate chains (docker-java#1371)
* Support for client certificate chains * Add test for client certificate chains Co-authored-by: Sergei Egorov <segorov@pivotal.io>
1 parent 8864acd commit ee2b249

File tree

2 files changed

+22
-4
lines changed

2 files changed

+22
-4
lines changed

docker-java-core/src/main/java/com/github/dockerjava/core/util/CertificateUtils.java

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -89,11 +89,13 @@ public static List<Certificate> loadCertificates(final Reader reader) throws IOE
8989

9090
JcaX509CertificateConverter certificateConverter = new JcaX509CertificateConverter()
9191
.setProvider(BouncyCastleProvider.PROVIDER_NAME);
92-
Object certObj = pemParser.readObject();
92+
Object certObj;
9393

94-
if (certObj instanceof X509CertificateHolder) {
95-
X509CertificateHolder certificateHolder = (X509CertificateHolder) certObj;
96-
certificates.add(certificateConverter.getCertificate(certificateHolder));
94+
while ((certObj = pemParser.readObject()) != null) {
95+
if (certObj instanceof X509CertificateHolder) {
96+
X509CertificateHolder certificateHolder = (X509CertificateHolder) certObj;
97+
certificates.add(certificateConverter.getCertificate(certificateHolder));
98+
}
9799
}
98100

99101
return certificates;

docker-java/src/test/java/com/github/dockerjava/core/util/CertificateUtilsTest.java

Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,8 @@
1111
import java.nio.file.Paths;
1212
import java.security.KeyStore;
1313
import java.security.Security;
14+
import java.security.cert.Certificate;
15+
import java.util.List;
1416

1517
import static org.hamcrest.MatcherAssert.assertThat;
1618
import static org.hamcrest.core.Is.is;
@@ -86,6 +88,20 @@ public void readMultipleCaCerts() throws Exception {
8688
assertThat(keyStore.isCertificateEntry("ca-2"), is(true));
8789
}
8890

91+
@Test
92+
public void readCert() throws Exception {
93+
String certpem = readFileAsString("caTest/single_ca.pem");
94+
List<Certificate> certs = CertificateUtils.loadCertificates(certpem);
95+
assertThat(certs.size(), is(1));
96+
}
97+
98+
@Test
99+
public void readMultipleCerts() throws Exception {
100+
String certpem = readFileAsString("caTest/multiple_ca.pem");
101+
List<Certificate> certs = CertificateUtils.loadCertificates(certpem);
102+
assertThat(certs.size(), is(2));
103+
}
104+
89105
private String readFileAsString(String path) throws IOException {
90106
return new String(Files.readAllBytes(Paths.get(new File(baseDir + path).getPath())));
91107
}

0 commit comments

Comments
 (0)