Regalamiunsorriso/decompiled-libs/www/acxent-skebby-1.0/it/acxent/skebby/api/UnsafeOkHttpSSL.java

49 lines
1.8 KiB
Java

package it.acxent.skebby.api;
import java.security.GeneralSecurityException;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.security.cert.X509Certificate;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSession;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
import okhttp3.OkHttpClient;
public class UnsafeOkHttpSSL {
private static TrustManager[] getAllTrustingTrustManager() {
return new TrustManager[] { new X509TrustManager() {
public void checkClientTrusted(X509Certificate[] chain, String authType) {}
public void checkServerTrusted(X509Certificate[] chain, String authType) {}
public X509Certificate[] getAcceptedIssuers() {
return new X509Certificate[0];
}
} };
}
private static SSLSocketFactory getUnsafeSslSocketFactory() {
try {
SSLContext sslContext = SSLContext.getInstance("TLS");
sslContext.init(null, getAllTrustingTrustManager(), new SecureRandom());
return sslContext.getSocketFactory();
} catch (NoSuchAlgorithmException|java.security.KeyManagementException e) {
throw new RuntimeException(e);
}
}
public static OkHttpClient getUnsafeOkHttpClient() {
try {
OkHttpClient.Builder builder = new OkHttpClient.Builder();
TrustManager[] trustAllCerts = getAllTrustingTrustManager();
X509TrustManager trustManager = (X509TrustManager)trustAllCerts[0];
builder.sslSocketFactory(getUnsafeSslSocketFactory(), trustManager);
builder.hostnameVerifier((hostname, session) -> true);
return builder.build();
} catch (Exception e) {
throw new RuntimeException(e);
}
}
}