/***************************************************************************** * Copyright (C) 2008 EnterpriseDB Corporation. * Copyright (C) 2011 Stado Global Development Group. * * This file is part of Stado. * * Stado is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Stado 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 for more details. * * You should have received a copy of the GNU General Public License * along with Stado. If not, see <http://www.gnu.org/licenses/>. * * You can find Stado at http://www.stado.us * ****************************************************************************/ package org.postgresql.driver.ssl; import javax.net.ssl.SSLContext; import javax.net.ssl.TrustManager; import javax.net.ssl.X509TrustManager; import java.security.cert.X509Certificate; import java.security.GeneralSecurityException; /** * Provide a SSLSocketFactory that allows SSL connections to be * made without validating the server's certificate. This is more * convenient for some applications, but is less secure as it allows * "man in the middle" attacks. */ public class NonValidatingFactory extends WrappedFactory { /** * We provide a constructor that takes an unused argument solely * because the ssl calling code will look for this constructor * first and then fall back to the no argument constructor, so * we avoid an exception and additional reflection lookups. */ public NonValidatingFactory(String arg) throws GeneralSecurityException { SSLContext ctx = SSLContext.getInstance("TLS"); // or "SSL" ? ctx.init(null, new TrustManager[] { new NonValidatingTM() }, null); _factory = ctx.getSocketFactory(); } static class NonValidatingTM implements X509TrustManager { public X509Certificate[] getAcceptedIssuers() { return new X509Certificate[0]; } public void checkClientTrusted(X509Certificate[] certs, String authType) { } public void checkServerTrusted(X509Certificate[] certs, String authType) { } } }