forked from robaho/httpserver
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSimpleSSLContext.java
More file actions
127 lines (115 loc) · 4.47 KB
/
SimpleSSLContext.java
File metadata and controls
127 lines (115 loc) · 4.47 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/*
* Copyright (c) 2005, 2022, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package jdk.test.lib.net;
import java.util.*;
import java.io.*;
import java.security.*;
import java.security.cert.*;
import java.util.function.Supplier;
import javax.net.ssl.*;
/**
* Creates a simple usable SSLContext for SSLSocketFactory or a HttpsServer
* using either a given keystore or a default one in the test tree.
*
* Using this class with a security manager requires the following permissions
* to be granted:
*
* permission "java.util.PropertyPermission" "test.src.path", "read"; permission
* java.io.FilePermission "/path/to/test/lib/jdk/test/lib/testkeys", "read"; The
* exact path above depends on the location of the test.
*/
public class SimpleSSLContext {
SSLContext ssl;
/**
* loads default keystore from SimpleSSLContext source directory
*/
public SimpleSSLContext() throws IOException {
this(() -> "TLS");
}
@SuppressWarnings("removal")
private SimpleSSLContext(Supplier<String> protocols) throws IOException {
try {
final String proto = protocols.get();
AccessController.doPrivileged(new PrivilegedExceptionAction<Void>() {
@Override
public Void run() throws Exception {
try (InputStream is = SimpleSSLContext.class.getResourceAsStream("/testkeys")) {
if (is == null) {
throw new IOException("unable to open testkeys");
}
init(is, proto);
return null;
}
}
});
} catch (PrivilegedActionException pae) {
Throwable t = pae.getCause() != null ? pae.getCause() : pae;
if (t instanceof IOException) {
throw (IOException) t;
}
if (t instanceof RuntimeException) {
throw (RuntimeException) t;
}
if (t instanceof Error) {
throw (Error) t;
}
throw new RuntimeException(t);
}
}
/**
* loads default keystore from given directory
*/
public SimpleSSLContext(String dir) throws IOException {
String file = dir + "/testkeys";
try (FileInputStream fis = new FileInputStream(file)) {
init(fis, "TLS");
}
}
private void init(InputStream i, String protocol) throws IOException {
try {
char[] passphrase = "passphrase".toCharArray();
KeyStore ks = KeyStore.getInstance("PKCS12");
ks.load(i, passphrase);
KeyManagerFactory kmf = KeyManagerFactory.getInstance("PKIX");
kmf.init(ks, passphrase);
TrustManagerFactory tmf = TrustManagerFactory.getInstance("PKIX");
tmf.init(ks);
ssl = SSLContext.getInstance(protocol);
ssl.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null);
} catch (KeyManagementException | KeyStoreException
| UnrecoverableKeyException | CertificateException
| NoSuchAlgorithmException e) {
throw new RuntimeException(e.getMessage());
}
}
public static SSLContext getContext(String protocol) throws IOException {
if (protocol == null || protocol.isEmpty()) {
return new SimpleSSLContext().get();
} else {
return new SimpleSSLContext(() -> protocol).get();
}
}
public SSLContext get() {
return ssl;
}
}