Skip to content

Commit d8decb5

Browse files
committed
Changed p12file type to InputStream
1 parent 77c681a commit d8decb5

File tree

4 files changed

+18
-13
lines changed

4 files changed

+18
-13
lines changed

client/src/main/java/io/split/client/SplitFactoryImpl.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -116,6 +116,8 @@
116116
import pluggable.CustomStorageWrapper;
117117

118118
import javax.net.ssl.SSLContext;
119+
import java.io.File;
120+
import java.io.FileInputStream;
119121
import java.io.IOException;
120122
import java.io.InputStream;
121123
import java.net.InetAddress;
@@ -606,7 +608,7 @@ private static SSLContext buildSSLContext(SplitClientConfig config) throws IOExc
606608
InputStream keystoreStream = null;
607609
try {
608610
KeyStore keyStore = KeyStore.getInstance("PKCS12");
609-
keystoreStream = java.nio.file.Files.newInputStream(Paths.get(config.proxyConfiguration().getP12File()));
611+
keystoreStream = config.proxyConfiguration().getP12File();
610612
keyStore.load(keystoreStream, config.proxyConfiguration().getPassKey().toCharArray());
611613
sslContext = SSLContexts.custom()
612614
.loadKeyMaterial(keyStore, config.proxyConfiguration().getPassKey().toCharArray())

client/src/main/java/io/split/client/dtos/ProxyConfiguration.java

Lines changed: 6 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -2,26 +2,27 @@
22

33
import org.apache.hc.core5.http.HttpHost;
44

5+
import java.io.InputStream;
56
import java.net.MalformedURLException;
67
import java.net.URL;
78

89
public class ProxyConfiguration {
910
private final HttpHost _proxyHost;
1011
private ProxyCredentialsProvider _provider;
11-
private final String _p12File;
12+
private final InputStream _p12File;
1213
private final String _passKey;
1314

1415
private ProxyConfiguration(HttpHost proxyHost,
1516
ProxyCredentialsProvider proxyCredentialsProvider,
16-
String p12File, String passKey) {
17+
InputStream p12File, String passKey) {
1718
_proxyHost = proxyHost;
1819
_p12File = p12File;
1920
_passKey = passKey;
2021
_provider = proxyCredentialsProvider;
2122
}
2223

2324
public HttpHost getHost() { return _proxyHost; }
24-
public String getP12File() { return _p12File; }
25+
public InputStream getP12File() { return _p12File; }
2526
public String getPassKey() { return _passKey; }
2627
public ProxyCredentialsProvider getProxyCredentialsProvider() { return _provider; }
2728

@@ -32,7 +33,7 @@ public static ProxyConfiguration.Builder builder() {
3233
public static class Builder {
3334
private ProxyCredentialsProvider _provider;
3435
private HttpHost _proxyHost;
35-
private String _p12File;
36+
private InputStream _p12File;
3637
private String _passKey;
3738

3839
public ProxyConfiguration.Builder credentialsProvider(ProxyCredentialsProvider provider) {
@@ -49,7 +50,7 @@ public ProxyConfiguration.Builder url(URL url) throws MalformedURLException {
4950
return this;
5051
}
5152

52-
public ProxyConfiguration.Builder mtls(String p12File, String passKey) {
53+
public ProxyConfiguration.Builder mtls(InputStream p12File, String passKey) {
5354
_passKey = passKey;
5455
_p12File = p12File;
5556
return this;

client/src/test/java/io/split/client/SplitClientConfigTest.java

Lines changed: 8 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,8 @@
1313
import org.junit.Test;
1414
import org.mockito.Mockito;
1515

16+
import java.io.FileInputStream;
17+
import java.io.FileNotFoundException;
1618
import java.net.MalformedURLException;
1719
import java.net.URL;
1820
import java.util.List;
@@ -260,7 +262,7 @@ public Map<String, List<String>> getHeaderOverrides(RequestContext context) {
260262
}
261263

262264
@Test
263-
public void checkProxyParams() throws MalformedURLException {
265+
public void checkProxyParams() throws MalformedURLException, FileNotFoundException {
264266
SplitClientConfig config = SplitClientConfig.builder()
265267
.proxyConfiguration(new ProxyConfiguration.Builder()
266268
.url(new URL("https://proxy-host:8888"))
@@ -304,14 +306,14 @@ public String getToken() {
304306
.build())
305307
.build();
306308
Assert.assertEquals(bearerCredentialsProvider, config.proxyConfiguration().getProxyCredentialsProvider());
307-
309+
FileInputStream p12File = new FileInputStream("src/test/resources/keyStore.p12");
308310
config = SplitClientConfig.builder()
309311
.proxyConfiguration(new ProxyConfiguration.Builder()
310312
.url(new URL("https://proxy-host:888"))
311-
.mtls("path/to/file", "pass-key")
313+
.mtls(p12File, "pass-key")
312314
.build())
313315
.build();
314-
Assert.assertEquals("path/to/file", config.proxyConfiguration().getP12File());
316+
Assert.assertEquals(p12File, config.proxyConfiguration().getP12File());
315317
Assert.assertEquals("pass-key", config.proxyConfiguration().getPassKey());
316318
}
317319

@@ -352,11 +354,11 @@ public void mustUseP12FileWithProxyMtls() throws MalformedURLException {
352354
}
353355

354356
@Test(expected = IllegalArgumentException.class)
355-
public void mustUseP12PassKeyWithProxyMtls() throws MalformedURLException {
357+
public void mustUseP12PassKeyWithProxyMtls() throws MalformedURLException, FileNotFoundException {
356358
SplitClientConfig.builder()
357359
.proxyConfiguration(new ProxyConfiguration.Builder()
358360
.url(new URL("https://proxy-host:888"))
359-
.mtls("path/to/file", null)
361+
.mtls(new FileInputStream("src/test/resources/keyStore.p12"), null)
360362
.build())
361363
.build();
362364
}

client/src/test/java/io/split/client/SplitFactoryImplTest.java

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -242,7 +242,7 @@ public void testFactoryInstantiationWithProxyMtls() throws Exception {
242242
.setBlockUntilReadyTimeout(1000)
243243
.proxyConfiguration(ProxyConfiguration.builder()
244244
.url(new URL("http://proxy-name:6060"))
245-
.mtls("src/test/resources/keyStore.p12", "split")
245+
.mtls(new FileInputStream("src/test/resources/keyStore.p12"), "split")
246246
.build())
247247
.build();
248248
SplitFactoryImpl splitFactory3 = new SplitFactoryImpl(API_KEY, splitClientConfig);

0 commit comments

Comments
 (0)