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