1
0
mirror of https://github.com/owncloud/android-library.git synced 2025-06-07 16:06:08 +00:00

Update parsing of PROPFIND responses to save, if exists, the value of the properties oc:permissions and oc:id

This commit is contained in:
jabarros 2014-06-24 12:41:40 +02:00
parent 6befcdafe5
commit 570c35c921

View File

@ -30,15 +30,17 @@ import org.apache.jackrabbit.webdav.MultiStatusResponse;
import org.apache.jackrabbit.webdav.property.DavProperty; import org.apache.jackrabbit.webdav.property.DavProperty;
import org.apache.jackrabbit.webdav.property.DavPropertyName; import org.apache.jackrabbit.webdav.property.DavPropertyName;
import org.apache.jackrabbit.webdav.property.DavPropertySet; import org.apache.jackrabbit.webdav.property.DavPropertySet;
import org.apache.jackrabbit.webdav.xml.Namespace;
import android.net.Uri; import android.net.Uri;
import android.util.Log; import android.util.Log;
public class WebdavEntry { public class WebdavEntry {
private String mName, mPath, mUri, mContentType, mEtag; private static final String NAMESPACE_OC = "http://owncloud.org/ns";
private static final String DAVPROPERTY_NAME_PERMISSIONS = "permissions";
private static final String DAVPROPERTY_NAME_REMOTE_ID = "id";
private String mName, mPath, mUri, mContentType, mEtag, mPermissions, mRemoteId;
private long mContentLength, mCreateTimestamp, mModifiedTimestamp; private long mContentLength, mCreateTimestamp, mModifiedTimestamp;
public WebdavEntry(MultiStatusResponse ms, String splitElement) { public WebdavEntry(MultiStatusResponse ms, String splitElement) {
@ -106,6 +108,18 @@ public class WebdavEntry {
mEtag = mEtag.substring(1, mEtag.length()-1); mEtag = mEtag.substring(1, mEtag.length()-1);
} }
// OC permissions property <oc:permissions>
prop = propSet.get(DAVPROPERTY_NAME_PERMISSIONS, Namespace.getNamespace(NAMESPACE_OC));
if (prop != null) {
mPermissions = prop.getValue().toString();
}
// OC remote id property <oc:id>
prop = propSet.get(DAVPROPERTY_NAME_REMOTE_ID, Namespace.getNamespace(NAMESPACE_OC));
if (prop != null) {
mRemoteId = prop.getValue().toString();
}
} else { } else {
Log.e("WebdavEntry", Log.e("WebdavEntry",
"General fuckup, no status for webdav response"); "General fuckup, no status for webdav response");
@ -152,8 +166,16 @@ public class WebdavEntry {
return mEtag; return mEtag;
} }
public String permissions() {
return mPermissions;
}
public String remoteId() {
return mRemoteId;
}
private void resetData() { private void resetData() {
mName = mUri = mContentType = null; mName = mUri = mContentType = mPermissions = null; mRemoteId = null;
mContentLength = mCreateTimestamp = mModifiedTimestamp = 0; mContentLength = mCreateTimestamp = mModifiedTimestamp = 0;
} }
} }