mirror of
https://github.com/owncloud/android-library.git
synced 2025-06-07 16:06:08 +00:00
206 lines
7.1 KiB
Java
206 lines
7.1 KiB
Java
/* ownCloud Android Library is available under MIT license
|
|
* Copyright (C) 2014 ownCloud Inc.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
|
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
|
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
* THE SOFTWARE.
|
|
*
|
|
*/
|
|
|
|
package com.owncloud.android.lib.common;
|
|
|
|
import java.io.IOException;
|
|
import java.util.HashMap;
|
|
import java.util.Iterator;
|
|
import java.util.Map;
|
|
|
|
import org.apache.commons.httpclient.cookie.CookiePolicy;
|
|
|
|
import android.accounts.Account;
|
|
import android.accounts.AuthenticatorException;
|
|
import android.accounts.OperationCanceledException;
|
|
import android.content.Context;
|
|
import android.net.Uri;
|
|
|
|
import com.owncloud.android.lib.common.accounts.AccountUtils;
|
|
import com.owncloud.android.lib.common.accounts.AccountUtils.AccountNotFoundException;
|
|
import com.owncloud.android.lib.common.utils.Log_OC;
|
|
|
|
/**
|
|
* Implementation of {@link OwnCloudClientManager}
|
|
*
|
|
* TODO check multithreading safety
|
|
*
|
|
* @author David A. Velasco
|
|
* @author masensio
|
|
*/
|
|
|
|
public class SingleSessionManager implements OwnCloudClientManager {
|
|
|
|
private static final String TAG = SingleSessionManager.class.getSimpleName();
|
|
|
|
private Map<String, OwnCloudClient> mClientsWithKnownUsername =
|
|
new HashMap<String, OwnCloudClient>();
|
|
|
|
private Map<String, OwnCloudClient> mClientsWithUnknownUsername =
|
|
new HashMap<String, OwnCloudClient>();
|
|
|
|
|
|
@Override
|
|
public synchronized OwnCloudClient getClientFor(OwnCloudAccount account, Context context)
|
|
throws AccountNotFoundException, OperationCanceledException, AuthenticatorException, IOException {
|
|
|
|
Log_OC.d(TAG, "getClientFor(OwnCloudAccount ... : ");
|
|
if (account == null) {
|
|
throw new IllegalArgumentException("Cannot get an OwnCloudClient for a null account");
|
|
}
|
|
|
|
OwnCloudClient client = null;
|
|
String accountName = account.getName();
|
|
String sessionName = account.getCredentials() == null ? "" :
|
|
AccountUtils.buildAccountName (
|
|
account.getBaseUri(),
|
|
account.getCredentials().getAuthToken()
|
|
)
|
|
;
|
|
|
|
if (accountName != null) {
|
|
client = mClientsWithKnownUsername.get(accountName);
|
|
}
|
|
boolean reusingKnown = false; // just for logs
|
|
if (client == null) {
|
|
if (accountName != null) {
|
|
client = mClientsWithUnknownUsername.remove(sessionName);
|
|
if (client != null) {
|
|
// TODO REMOVE THIS LOG
|
|
Log_OC.d(TAG, " reusing client {" + sessionName + ", " +
|
|
client.hashCode() + "}");
|
|
mClientsWithKnownUsername.put(accountName, client);
|
|
Log_OC.d(TAG, " moved client to {" + accountName + ", " +
|
|
client.hashCode() + "}");
|
|
}
|
|
} else {
|
|
client = mClientsWithUnknownUsername.get(sessionName);
|
|
}
|
|
} else {
|
|
Log_OC.d(TAG, " reusing client {" + accountName + ", " + client.hashCode() + "}");
|
|
reusingKnown = true;
|
|
}
|
|
|
|
if (client == null) {
|
|
// no client to reuse - create a new one
|
|
client = OwnCloudClientFactory.createOwnCloudClient(
|
|
account.getBaseUri(),
|
|
context.getApplicationContext(),
|
|
true); // TODO remove dependency on OwnCloudClientFactory
|
|
client.getParams().setCookiePolicy(CookiePolicy.BROWSER_COMPATIBILITY);
|
|
// enable cookie tracking
|
|
|
|
AccountUtils.restoreCookies(accountName, client, context);
|
|
|
|
account.loadCredentials(context);
|
|
client.setCredentials(account.getCredentials());
|
|
if (accountName != null) {
|
|
mClientsWithKnownUsername.put(accountName, client);
|
|
Log_OC.d(TAG, " new client {" + accountName + ", " + client.hashCode() + "}");
|
|
|
|
} else {
|
|
mClientsWithUnknownUsername.put(sessionName, client);
|
|
// TODO REMOVE THIS LOG
|
|
Log_OC.d(TAG, " new client {" + sessionName + ", " + client.hashCode() + "}");
|
|
}
|
|
} else {
|
|
if (!reusingKnown) {
|
|
// TODO REMOVE THIS LOG
|
|
Log_OC.d(TAG, " reusing client {" + sessionName + ", " + client.hashCode() + "}");
|
|
}
|
|
keepCredentialsUpdated(account, client);
|
|
keepUriUpdated(account, client);
|
|
}
|
|
|
|
return client;
|
|
}
|
|
|
|
|
|
@Override
|
|
public OwnCloudClient removeClientFor(OwnCloudAccount account) {
|
|
|
|
if (account == null) {
|
|
return null;
|
|
}
|
|
|
|
OwnCloudClient client = null;
|
|
String accountName = account.getName();
|
|
if (accountName != null) {
|
|
client = mClientsWithKnownUsername.remove(accountName);
|
|
if (client != null) {
|
|
Log_OC.d(TAG, "Removed client {" + accountName + ", " + client.hashCode() + "}");
|
|
return client;
|
|
} else {
|
|
Log_OC.d(TAG, "No client tracked for {" + accountName + "}");
|
|
}
|
|
}
|
|
|
|
mClientsWithUnknownUsername.clear();
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
public synchronized void saveAllClients(Context context, String accountType)
|
|
throws AccountNotFoundException, AuthenticatorException, IOException,
|
|
OperationCanceledException {
|
|
|
|
Iterator<String> accountNames = mClientsWithKnownUsername.keySet().iterator();
|
|
String accountName = null;
|
|
Account account = null;
|
|
while (accountNames.hasNext()) {
|
|
accountName = accountNames.next();
|
|
account = new Account(accountName, accountType);
|
|
AccountUtils.saveClient(
|
|
mClientsWithKnownUsername.get(accountName),
|
|
account,
|
|
context);
|
|
}
|
|
}
|
|
|
|
|
|
private void keepCredentialsUpdated(OwnCloudAccount account, OwnCloudClient reusedClient) {
|
|
OwnCloudCredentials recentCredentials = account.getCredentials();
|
|
if (recentCredentials != null && !recentCredentials.getAuthToken().equals(
|
|
reusedClient.getCredentials().getAuthToken())) {
|
|
reusedClient.setCredentials(recentCredentials);
|
|
}
|
|
|
|
}
|
|
|
|
// this method is just a patch; we need to distinguish accounts in the same host but
|
|
// different paths; but that requires updating the accountNames for apps upgrading
|
|
private void keepUriUpdated(OwnCloudAccount account, OwnCloudClient reusedClient) {
|
|
Uri recentUri = account.getBaseUri();
|
|
if (!recentUri.equals(reusedClient.getBaseUri())) {
|
|
reusedClient.setBaseUri(recentUri);
|
|
}
|
|
|
|
}
|
|
|
|
|
|
}
|