blob: 03daae3a89b2c1e771c1723ba5ddbe29dafc02f5 [file] [log] [blame]
/* $Id: KeystoreManagerFactory.java 988245 2010-08-23 18:39:35Z kwright $ */
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.manifoldcf.connectorcommon.interfaces;
import org.apache.manifoldcf.connectorcommon.keystore.KeystoreManager;
import org.apache.manifoldcf.core.interfaces.*;
import java.security.*;
import java.security.cert.*;
/** This class is the factory class for keystore managers.
*/
public class KeystoreManagerFactory
{
public static final String _rcsid = "@(#)$Id: KeystoreManagerFactory.java 988245 2010-08-23 18:39:35Z kwright $";
/** Mint a keystore manager.
*/
public static IKeystoreManager make(String passcode)
throws ManifoldCFException
{
return new KeystoreManager(passcode);
}
/** Mint a keystore manager from a base-64 encoded string.
*/
public static IKeystoreManager make(String passcode, String base64String)
throws ManifoldCFException
{
return new KeystoreManager(passcode,base64String);
}
protected static javax.net.ssl.X509TrustManager[] openTrustManagerArray = new OpenTrustManager[]{new OpenTrustManager()};
/** Build a secure socket factory that pays no attention to certificates in trust store, and just trusts everything.
*/
public static javax.net.ssl.SSLSocketFactory getTrustingSecureSocketFactory()
throws ManifoldCFException
{
try
{
java.security.SecureRandom secureRandom = java.security.SecureRandom.getInstance("SHA1PRNG");
// Create an SSL context
javax.net.ssl.SSLContext sslContext = javax.net.ssl.SSLContext.getInstance("SSL");
sslContext.init(null,openTrustManagerArray,secureRandom);
return sslContext.getSocketFactory();
}
catch (java.security.NoSuchAlgorithmException e)
{
throw new ManifoldCFException("No such algorithm: "+e.getMessage(),e);
}
catch (java.security.KeyManagementException e)
{
throw new ManifoldCFException("Key management exception: "+e.getMessage(),e);
}
}
protected static class OpenTrustManager implements javax.net.ssl.X509TrustManager
{
public void checkClientTrusted(X509Certificate[] chain,
String authType)
throws CertificateException
{
}
public void checkServerTrusted(X509Certificate[] chain,
String authType)
throws CertificateException
{
}
public X509Certificate[] getAcceptedIssuers()
{
return new X509Certificate[0];
}
}
}