1561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes/*
2561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  Licensed to the Apache Software Foundation (ASF) under one or more
3561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  contributor license agreements.  See the NOTICE file distributed with
4561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  this work for additional information regarding copyright ownership.
5561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  The ASF licenses this file to You under the Apache License, Version 2.0
6561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  (the "License"); you may not use this file except in compliance with
7561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  the License.  You may obtain a copy of the License at
8561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *
9561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *     http://www.apache.org/licenses/LICENSE-2.0
10561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *
11561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  Unless required by applicable law or agreed to in writing, software
12561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  distributed under the License is distributed on an "AS IS" BASIS,
13561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  See the License for the specific language governing permissions and
15561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  limitations under the License.
16561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes */
17561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
18561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughespackage org.apache.harmony.xnet.provider.jsse;
19561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
20561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.io.InputStream;
21561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.security.KeyStore;
22561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.security.SecureRandom;
23561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
24561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport javax.net.ssl.KeyManagerFactory;
25561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport javax.net.ssl.SSLContext;
26561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport javax.net.ssl.TrustManagerFactory;
27561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
28561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport tests.support.resource.Support_Resources;
29561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
30561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes/**
31561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * JSSETestData
32561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes */
33561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughespublic class JSSETestData {
34561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
35561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    private static Exception initException;
36561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
37561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    // the password to the store
38561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    public static final char[] KS_PASSWORD = "password".toCharArray();
39561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
40561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    private static SSLContext context;
41561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    private static KeyStore keyStore;
42561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    private static SSLParameters sslParameters;
43561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
44561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    static {
45561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        try {
46561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            String ksDefaultType = KeyStore.getDefaultType();
47561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            InputStream is = Support_Resources.getResourceStream(
48561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                    "key_store." + ksDefaultType.toLowerCase());
49561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
50561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            keyStore = KeyStore.getInstance(ksDefaultType);
51561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            keyStore.load(is, KS_PASSWORD);
52561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
53561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            KeyManagerFactory kmf = KeyManagerFactory.getInstance("X509");
54561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            kmf.init(keyStore, KS_PASSWORD);
55561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
56561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            TrustManagerFactory tmf = TrustManagerFactory.getInstance("X509");
57561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            tmf.init(keyStore);
58561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
59561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            sslParameters = new SSLParameters(kmf.getKeyManagers(), tmf
60561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                    .getTrustManagers(), new SecureRandom(),
61561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                    new SSLSessionContextImpl(), new SSLSessionContextImpl());
62561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
63561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            context = SSLContext.getInstance("TLSv1");
64561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            context.init(kmf.getKeyManagers(),
65561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                    tmf.getTrustManagers(), new SecureRandom());
66561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        } catch (Exception e) {
67561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            e.printStackTrace();
68561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            initException = e;
69561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        }
70561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    }
71561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
72561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    public static SSLContext getContext() throws Exception {
73561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        if (initException != null) {
74561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            throw initException;
75561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        }
76561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        return context;
77561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    }
78561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
79561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    public static SSLParameters getSSLParameters() throws Exception {
80561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        if (initException != null) {
81561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            throw initException;
82561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        }
83561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        return sslParameters;
84561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    }
85561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
86561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    public static KeyStore getKeyStore() throws Exception {
87561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        if (initException != null) {
88561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            throw initException;
89561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        }
90561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        return keyStore;
91561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    }
92561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes}
93