import android.net.Uri;\r
import android.text.TextUtils;\r
import eu.alefzero.owncloud.authenticator.AccountAuthenticator;\r
+import eu.alefzero.owncloud.datamodel.OCFile;\r
import eu.alefzero.webdav.HttpPropFind;\r
import eu.alefzero.webdav.TreeNode;\r
+import eu.alefzero.webdav.TreeNode.NodeProperty;\r
import eu.alefzero.webdav.WebdavClient;\r
import eu.alefzero.webdav.WebdavUtils;\r
-import eu.alefzero.webdav.TreeNode.NodeProperty;\r
/**
* Base SyncAdapter for OwnCloud
- * Designed to be subclassed for the concreete SyncAdapter, like ConcatsSync, CalendarSync, FileSync etc..
+ * Designed to be subclassed for the concrete SyncAdapter, like ConcatsSync, CalendarSync, FileSync etc..
*
* @author sassman
*
protected ConnectionKeepAliveStrategy getKeepAliveStrategy() {
return new ConnectionKeepAliveStrategy() {
public long getKeepAliveDuration(HttpResponse response, HttpContext context) {
- // TODO: change keep alive straategy basing on response: ie forbidden/not found/etc
+ // Change keep alive straategy basing on response: ie forbidden/not found/etc
// should have keep alive 0
- // default return: 5s
+ // default return: 5s\r
+ int statusCode = response.getStatusLine().getStatusCode();\r
+ \r
+ // HTTP 400, 500 Errors as well as HTTP 118 - Connection timed out\r
+ if((statusCode >= 400 && statusCode <= 418) || \r
+ (statusCode >= 421 && statusCode <= 426) ||\r
+ (statusCode >= 500 && statusCode <= 510 ) ||\r
+ statusCode == 118) {\r
+ return 0;\r
+ }\r
+
return 5 * 1000;
}
};
HttpResponse response = fireRawRequest(query);
TreeNode root = new TreeNode();
- root.setProperty(TreeNode.NodeProperty.NAME, "/");
- this.parseResponse(response, getUri(), getClient(), mHost, root.getChildList());
+ root.setProperty(TreeNode.NodeProperty.NAME, "");
+ this.parseResponse(response, getUri(), getClient(), mHost, root.getChildList(), false, 0);
return root;
}
return mClient.getHttpClient();
}
- private void parseResponse(HttpResponse resp, Uri uri, DefaultHttpClient client, HttpHost targetHost, LinkedList<TreeNode> insertList) throws IOException, OperationCanceledException, AuthenticatorException {
- boolean skipFirst = true;
- for (TreeNode n :WebdavUtils.parseResponseToNodes(resp.getEntity().getContent())) {
- String path = n.stripPathFromFilename(uri.getPath());
- if (skipFirst) {
- skipFirst = false;
- continue;
+ private void parseResponse(HttpResponse resp, Uri uri, DefaultHttpClient client, HttpHost targetHost, LinkedList<TreeNode> insertList, boolean sf, long parent_id) throws IOException, OperationCanceledException, AuthenticatorException {
+ boolean skipFirst = sf, override_parent = !sf;
+ for (TreeNode n :WebdavUtils.parseResponseToNodes(resp.getEntity().getContent())) {\r
+ if (skipFirst) {\r
+ skipFirst = false;\r
+ continue;\r
+ }
+ String path = n.stripPathFromFilename(uri.getPath());\r
+ OCFile new_file = OCFile.createNewFile(getContentProvider(),\r
+ getAccount(),\r
+ n.getProperty(NodeProperty.PATH),\r
+ 0,//Long.parseLong(n.getProperty(NodeProperty.CONTENT_LENGTH)),\r
+ 0,//Long.parseLong(n.getProperty(NodeProperty.CREATE_DATE)),\r
+ 0,//Long.parseLong(n.getProperty(NodeProperty.LAST_MODIFIED_DATE)),\r
+ n.getProperty(NodeProperty.RESOURCE_TYPE),\r
+ parent_id);\r
+ new_file.save();\r
+ if (override_parent) {\r
+ parent_id = new_file.getFileId();\r
+ override_parent = false;\r
}
- insertList.add(n);
if (!TextUtils.isEmpty(n.getProperty(NodeProperty.NAME)) &&
n.getProperty(NodeProperty.RESOURCE_TYPE).equals("DIR")) {
HttpPropFind method = new HttpPropFind(uri.getPath() + path + n.getProperty(NodeProperty.NAME).replace(" ", "%20") + "/");
HttpResponse response = fireRawRequest(method);
- parseResponse(response, uri, client, targetHost, n.getChildList());
+ parseResponse(response, uri, client, targetHost, n.getChildList(), true, new_file.getFileId());
}
}
}