X-Git-Url: http://git.linex4red.de/pub/Android/ownCloud.git/blobdiff_plain/69445038745b47f72693befc67cca72c305786d6..aae90eb1aa42a11449e30330e3e23e1e9e5eebb6:/src/com/owncloud/android/authentication/SsoWebViewClient.java?ds=sidebyside diff --git a/src/com/owncloud/android/authentication/SsoWebViewClient.java b/src/com/owncloud/android/authentication/SsoWebViewClient.java index 23793e0d..fb078bdf 100644 --- a/src/com/owncloud/android/authentication/SsoWebViewClient.java +++ b/src/com/owncloud/android/authentication/SsoWebViewClient.java @@ -24,9 +24,6 @@ import java.security.cert.CertificateException; import java.security.cert.CertificateFactory; import java.security.cert.X509Certificate; -import com.owncloud.android.lib.common.network.NetworkUtils; -import com.owncloud.android.utils.Log_OC; - import android.content.Context; import android.graphics.Bitmap; import android.net.http.SslCertificate; @@ -43,6 +40,9 @@ import android.webkit.WebResourceResponse; import android.webkit.WebView; import android.webkit.WebViewClient; +import com.owncloud.android.lib.common.network.NetworkUtils; +import com.owncloud.android.utils.Log_OC; + /** * Custom {@link WebViewClient} client aimed to catch the end of a single-sign-on process @@ -66,6 +66,7 @@ public class SsoWebViewClient extends WebViewClient { private WeakReference mListenerRef; private String mTargetUrl; private String mLastReloadedUrlAtError; + public SsoWebViewClient (Context context, Handler listenerHandler, SsoWebViewClientListener listener) { mContext = context; @@ -86,6 +87,7 @@ public class SsoWebViewClient extends WebViewClient { @Override public void onPageStarted (WebView view, String url, Bitmap favicon) { Log_OC.d(TAG, "onPageStarted : " + url); + view.clearCache(true); super.onPageStarted(view, url, favicon); } @@ -150,28 +152,22 @@ public class SsoWebViewClient extends WebViewClient { Log_OC.d(TAG, "onReceivedSslError : " + error); // Test 1 X509Certificate x509Certificate = getX509CertificateFromError(error); - boolean isKnowServer = false; + boolean isKnownServer = false; if (x509Certificate != null) { Log_OC.d(TAG, "------>>>>> x509Certificate " + x509Certificate.toString()); try { - isKnowServer = NetworkUtils.isCertInKnownServersStore((Certificate) x509Certificate, mContext); + isKnownServer = NetworkUtils.isCertInKnownServersStore((Certificate) x509Certificate, mContext); } catch (Exception e) { Log_OC.e(TAG, "Exception: " + e.getMessage()); } } - if (isKnowServer) { + if (isKnownServer) { handler.proceed(); } else { - // Show a dialog with the certificate info - ((AuthenticatorActivity)mContext).showUntrustedCertDialog(x509Certificate, error); -// SslUntrustedCertDialog dialog = SslUntrustedCertDialog.newInstance(mContext, x509Certificate, error); -// FragmentManager fm = ((FragmentActivity)mContext).getSupportFragmentManager(); -// FragmentTransaction ft = fm.beginTransaction(); -// dialog.show(ft, DIALOG_UNTRUSTED_CERT); - handler.cancel(); + ((AuthenticatorActivity)mContext).showUntrustedCertDialog(x509Certificate, error, handler); } } @@ -201,6 +197,8 @@ public class SsoWebViewClient extends WebViewClient { @Override public void onReceivedHttpAuthRequest (WebView view, HttpAuthHandler handler, String host, String realm) { Log_OC.d(TAG, "onReceivedHttpAuthRequest : " + host); + + ((AuthenticatorActivity)mContext).createAuthenticationDialog(view, handler); } @Override @@ -235,5 +233,4 @@ public class SsoWebViewClient extends WebViewClient { Log_OC.d(TAG, "shouldOverrideKeyEvent : " + event); return false; } - }