svn commit: r529427 - /ofbiz/trunk/framework/base/src/base/org/ofbiz/base/util/SSLUtil.java

Previous Topic Next Topic
 
classic Classic list List threaded Threaded
1 message Options
Reply | Threaded
Open this post in threaded view
|

svn commit: r529427 - /ofbiz/trunk/framework/base/src/base/org/ofbiz/base/util/SSLUtil.java

jaz-3
Author: jaz
Date: Mon Apr 16 15:48:52 2007
New Revision: 529427

URL: http://svn.apache.org/viewvc?view=rev&rev=529427
Log:
implemented hostname verifier so that SSL certs do not HAVE to match that of the site; as long as we add them to the trust store

Modified:
    ofbiz/trunk/framework/base/src/base/org/ofbiz/base/util/SSLUtil.java

Modified: ofbiz/trunk/framework/base/src/base/org/ofbiz/base/util/SSLUtil.java
URL: http://svn.apache.org/viewvc/ofbiz/trunk/framework/base/src/base/org/ofbiz/base/util/SSLUtil.java?view=diff&rev=529427&r1=529426&r2=529427
==============================================================================
--- ofbiz/trunk/framework/base/src/base/org/ofbiz/base/util/SSLUtil.java (original)
+++ ofbiz/trunk/framework/base/src/base/org/ofbiz/base/util/SSLUtil.java Mon Apr 16 15:48:52 2007
@@ -22,6 +22,8 @@
 import java.security.GeneralSecurityException;
 import java.security.KeyStore;
 import java.security.SecureRandom;
+import java.util.Map;
+import java.util.HashMap;
 
 import javax.net.ssl.*;
 
@@ -32,6 +34,11 @@
 public class SSLUtil {
 
     public static final String module = SSLUtil.class.getName();
+
+    public static final int HOSTCERT_NO_CHECK = 0;
+    public static final int HOSTCERT_MIN_CHECK = 1;
+    public static final int HOSTCERT_NORMAL_CHECK = 2;
+
     private static boolean loadedProps = false;
 
     static {
@@ -84,6 +91,54 @@
         SSLContext context = SSLContext.getInstance("SSL");
         context.init(km, tm, null);
         return context.getServerSocketFactory();
+    }
+
+    public static HostnameVerifier getHostnameVerifier(int level) {
+        switch(level) {          
+            case HOSTCERT_MIN_CHECK:
+                return new HostnameVerifier() {
+                    public boolean verify(String hostname, SSLSession session) {
+                        Debug.log("Checking: " + hostname + " :: " + session.getPeerHost(), module);
+                        javax.security.cert.X509Certificate[] peerCerts;
+                        try {
+                            peerCerts = session.getPeerCertificateChain();
+                        } catch (SSLPeerUnverifiedException e) {
+                            // cert not verified
+                            Debug.logWarning(e.getMessage(), module);
+                            return false;
+                        }
+                        for (int i = 0; i < peerCerts.length; i++) {
+                            Map certMap = new HashMap();
+                            String name = peerCerts[i].getSubjectDN().getName();
+                            String[] sections = name.split("\\,");
+                            for (int si = 0; si < sections.length; si++) {
+                                String[] nv = sections[si].split("\\=");
+                                for (int nvi = 0; nvi < nv.length; nvi++) {
+                                    certMap.put(nv[0], nv[1]);
+                                }
+                            }
+
+                            Debug.log(peerCerts[i].getSerialNumber().toString(16) + " :: " + certMap.get("CN"), module);
+                            try {
+                                peerCerts[i].checkValidity();
+                            } catch (Exception e) {
+                                // certificate not valid
+                                Debug.logWarning("Certificate is not valid!", module);
+                                return false;
+                            }
+                        }
+                        return true;
+                    }
+                };
+            case HOSTCERT_NO_CHECK:
+                return new HostnameVerifier() {
+                    public boolean verify(String hostname, SSLSession session) {
+                        return true;
+                    }
+                };
+            default:
+                return null;
+        }
     }
 
     public static void loadJsseProperties() {