Merge pull request #366 from owncloud/bug_handling_failure_in_request_for_remote_username
[pub/Android/ownCloud.git] / src / com / owncloud / android / operations / UpdateOCVersionOperation.java
1 /* ownCloud Android client application
2 * Copyright (C) 2012-2013 ownCloud Inc.
3 *
4 * This program is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2,
6 * as published by the Free Software Foundation.
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program. If not, see <http://www.gnu.org/licenses/>.
15 *
16 */
17
18 package com.owncloud.android.operations;
19
20 import org.apache.commons.httpclient.HttpStatus;
21 import org.apache.commons.httpclient.methods.GetMethod;
22 import org.json.JSONException;
23 import org.json.JSONObject;
24
25 import com.owncloud.android.authentication.AccountUtils;
26 import com.owncloud.android.lib.accounts.OwnCloudAccount;
27 import com.owncloud.android.lib.network.OwnCloudClient;
28 import com.owncloud.android.lib.operations.common.RemoteOperation;
29 import com.owncloud.android.lib.operations.common.RemoteOperationResult;
30 import com.owncloud.android.lib.operations.common.RemoteOperationResult.ResultCode;
31 import com.owncloud.android.lib.utils.OwnCloudVersion;
32 import com.owncloud.android.utils.Log_OC;
33
34 import android.accounts.Account;
35 import android.accounts.AccountManager;
36 import android.content.Context;
37
38
39 /**
40 * Remote operation that checks the version of an ownCloud server and stores it locally
41 *
42 * @author David A. Velasco
43 */
44 public class UpdateOCVersionOperation extends RemoteOperation {
45
46 private static final String TAG = UpdateOCVersionOperation.class.getSimpleName();
47
48 private Account mAccount;
49 private Context mContext;
50
51
52 public UpdateOCVersionOperation(Account account, Context context) {
53 mAccount = account;
54 mContext = context;
55 }
56
57
58 @Override
59 protected RemoteOperationResult run(OwnCloudClient client) {
60 AccountManager accountMngr = AccountManager.get(mContext);
61 String statUrl = accountMngr.getUserData(mAccount, OwnCloudAccount.Constants.KEY_OC_BASE_URL);
62 statUrl += AccountUtils.STATUS_PATH;
63 RemoteOperationResult result = null;
64 GetMethod get = null;
65 try {
66 get = new GetMethod(statUrl);
67 int status = client.executeMethod(get);
68 if (status != HttpStatus.SC_OK) {
69 client.exhaustResponse(get.getResponseBodyAsStream());
70 result = new RemoteOperationResult(false, status, get.getResponseHeaders());
71
72 } else {
73 String response = get.getResponseBodyAsString();
74 if (response != null) {
75 JSONObject json = new JSONObject(response);
76 if (json != null && json.getString("version") != null) {
77 OwnCloudVersion ocver = new OwnCloudVersion(json.getString("version"));
78 if (ocver.isVersionValid()) {
79 accountMngr.setUserData(mAccount, OwnCloudAccount.Constants.KEY_OC_VERSION, ocver.toString());
80 Log_OC.d(TAG, "Got new OC version " + ocver.toString());
81 result = new RemoteOperationResult(ResultCode.OK);
82
83 } else {
84 Log_OC.w(TAG, "Invalid version number received from server: " + json.getString("version"));
85 result = new RemoteOperationResult(RemoteOperationResult.ResultCode.BAD_OC_VERSION);
86 }
87 }
88 }
89 if (result == null) {
90 result = new RemoteOperationResult(RemoteOperationResult.ResultCode.INSTANCE_NOT_CONFIGURED);
91 }
92 }
93 Log_OC.i(TAG, "Check for update of ownCloud server version at " + client.getBaseUri() + ": " + result.getLogMessage());
94
95 } catch (JSONException e) {
96 result = new RemoteOperationResult(RemoteOperationResult.ResultCode.INSTANCE_NOT_CONFIGURED);
97 Log_OC.e(TAG, "Check for update of ownCloud server version at " + client.getBaseUri() + ": " + result.getLogMessage(), e);
98
99 } catch (Exception e) {
100 result = new RemoteOperationResult(e);
101 Log_OC.e(TAG, "Check for update of ownCloud server version at " + client.getBaseUri() + ": " + result.getLogMessage(), e);
102
103 } finally {
104 if (get != null)
105 get.releaseConnection();
106 }
107 return result;
108 }
109
110 }