X-Git-Url: http://git.linex4red.de/pub/Android/ownCloud.git/blobdiff_plain/5ac1a1ebbb78aaa7b85318bd7542b1c047291d19..991f4242f0415069e289ec0897d7c64a19e9d061:/src/com/owncloud/android/operations/DetectAuthenticationMethodOperation.java diff --git a/src/com/owncloud/android/operations/DetectAuthenticationMethodOperation.java b/src/com/owncloud/android/operations/DetectAuthenticationMethodOperation.java index 6bc87503..5afc4210 100644 --- a/src/com/owncloud/android/operations/DetectAuthenticationMethodOperation.java +++ b/src/com/owncloud/android/operations/DetectAuthenticationMethodOperation.java @@ -31,11 +31,11 @@ import com.owncloud.android.lib.common.operations.OnRemoteOperationListener; import com.owncloud.android.lib.common.operations.RemoteOperation; import com.owncloud.android.lib.common.operations.RemoteOperationResult; import com.owncloud.android.lib.common.operations.RemoteOperationResult.ResultCode; +import com.owncloud.android.lib.common.utils.Log_OC; import com.owncloud.android.lib.resources.files.ExistenceCheckRemoteOperation; import android.content.Context; import android.net.Uri; -import android.util.Log; /** * Operation to find out what authentication method requires @@ -64,7 +64,6 @@ public class DetectAuthenticationMethodOperation extends RemoteOperation { } private Context mContext; - private String mWebDavUrl; /** * Constructor @@ -72,9 +71,8 @@ public class DetectAuthenticationMethodOperation extends RemoteOperation { * @param context Android context of the caller. * @param webdavUrl */ - public DetectAuthenticationMethodOperation(Context context, String webdavUrl) { + public DetectAuthenticationMethodOperation(Context context) { mContext = context; - mWebDavUrl = webdavUrl; } @@ -93,15 +91,15 @@ public class DetectAuthenticationMethodOperation extends RemoteOperation { AuthenticationMethod authMethod = AuthenticationMethod.UNKNOWN; RemoteOperation operation = new ExistenceCheckRemoteOperation("", mContext, false); - client.setWebdavUri(Uri.parse(mWebDavUrl)); - client.setBasicCredentials("", ""); + client.clearCredentials(); client.setFollowRedirects(false); // try to access the root folder, following redirections but not SAML SSO redirections result = operation.execute(client); String redirectedLocation = result.getRedirectedLocation(); - while (redirectedLocation != null && redirectedLocation.length() > 0 && !result.isIdPRedirection()) { - client.setWebdavUri(Uri.parse(result.getRedirectedLocation())); + while (redirectedLocation != null && redirectedLocation.length() > 0 && + !result.isIdPRedirection()) { + client.setBaseUri(Uri.parse(result.getRedirectedLocation())); result = operation.execute(client); redirectedLocation = result.getRedirectedLocation(); } @@ -124,8 +122,11 @@ public class DetectAuthenticationMethodOperation extends RemoteOperation { authMethod = AuthenticationMethod.SAML_WEB_SSO; } // else - fall back to UNKNOWN - Log.d(TAG, "Authentication method found: " + authenticationMethodToString(authMethod)); + Log_OC.d(TAG, "Authentication method found: " + authenticationMethodToString(authMethod)); + if (!authMethod.equals(AuthenticationMethod.UNKNOWN)) { + result = new RemoteOperationResult(true, result.getHttpCode(), null); + } ArrayList data = new ArrayList(); data.add(authMethod); result.setData(data);