mirror of
https://github.com/owncloud/android-library.git
synced 2025-06-07 16:06:08 +00:00
Merge branch 'master' into develop
This commit is contained in:
commit
cd4414a7bd
@ -80,10 +80,11 @@ public class AccountUtils {
|
|||||||
public static String constructFullURLForAccount(Context context, Account account) throws AccountNotFoundException {
|
public static String constructFullURLForAccount(Context context, Account account) throws AccountNotFoundException {
|
||||||
AccountManager ama = AccountManager.get(context);
|
AccountManager ama = AccountManager.get(context);
|
||||||
String baseurl = ama.getUserData(account, Constants.KEY_OC_BASE_URL);
|
String baseurl = ama.getUserData(account, Constants.KEY_OC_BASE_URL);
|
||||||
String strver = ama.getUserData(account, Constants.KEY_OC_VERSION);
|
String version = ama.getUserData(account, Constants.KEY_OC_VERSION);
|
||||||
|
String versionString = ama.getUserData(account, Constants.KEY_OC_VERSION_STRING);
|
||||||
boolean supportsOAuth = (ama.getUserData(account, Constants.KEY_SUPPORTS_OAUTH2) != null);
|
boolean supportsOAuth = (ama.getUserData(account, Constants.KEY_SUPPORTS_OAUTH2) != null);
|
||||||
boolean supportsSamlSso = (ama.getUserData(account, Constants.KEY_SUPPORTS_SAML_WEB_SSO) != null);
|
boolean supportsSamlSso = (ama.getUserData(account, Constants.KEY_SUPPORTS_SAML_WEB_SSO) != null);
|
||||||
OwnCloudVersion ver = new OwnCloudVersion(strver);
|
OwnCloudVersion ver = new OwnCloudVersion(version, versionString);
|
||||||
String webdavpath = getWebdavPath(ver, supportsOAuth, supportsSamlSso);
|
String webdavpath = getWebdavPath(ver, supportsOAuth, supportsSamlSso);
|
||||||
|
|
||||||
if (baseurl == null || webdavpath == null)
|
if (baseurl == null || webdavpath == null)
|
||||||
@ -148,6 +149,10 @@ public class AccountUtils {
|
|||||||
* http://server/path or https://owncloud.server
|
* http://server/path or https://owncloud.server
|
||||||
*/
|
*/
|
||||||
public static final String KEY_OC_BASE_URL = "oc_base_url";
|
public static final String KEY_OC_BASE_URL = "oc_base_url";
|
||||||
|
/**
|
||||||
|
* Version string as shown in the status.php resource in the server side
|
||||||
|
*/
|
||||||
|
public static final String KEY_OC_VERSION_STRING = "oc_version_string";
|
||||||
/**
|
/**
|
||||||
* Flag signaling if the ownCloud server can be accessed with OAuth2 access tokens.
|
* Flag signaling if the ownCloud server can be accessed with OAuth2 access tokens.
|
||||||
*/
|
*/
|
||||||
|
@ -220,7 +220,8 @@ public class ShareXMLParser {
|
|||||||
}
|
}
|
||||||
String name = parser.getName();
|
String name = parser.getName();
|
||||||
if (name.equalsIgnoreCase(NODE_ELEMENT)) {
|
if (name.equalsIgnoreCase(NODE_ELEMENT)) {
|
||||||
shares.add(readElement(parser));
|
readElement(parser, shares);
|
||||||
|
|
||||||
} else if (name.equalsIgnoreCase(NODE_ID)) {// Parse Create XML Response
|
} else if (name.equalsIgnoreCase(NODE_ID)) {// Parse Create XML Response
|
||||||
share = new OCShare();
|
share = new OCShare();
|
||||||
String value = readNode(parser, NODE_ID);
|
String value = readNode(parser, NODE_ID);
|
||||||
@ -241,10 +242,10 @@ public class ShareXMLParser {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (share != null) {
|
if (share != null) {
|
||||||
|
// this is the response of a request for creation; don't pass to isValidShare()
|
||||||
shares.add(share);
|
shares.add(share);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
return shares;
|
return shares;
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -257,7 +258,7 @@ public class ShareXMLParser {
|
|||||||
* @throws XmlPullParserException
|
* @throws XmlPullParserException
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
private OCShare readElement(XmlPullParser parser) throws XmlPullParserException, IOException {
|
private void readElement(XmlPullParser parser, ArrayList<OCShare> shares) throws XmlPullParserException, IOException {
|
||||||
parser.require(XmlPullParser.START_TAG, ns, NODE_ELEMENT);
|
parser.require(XmlPullParser.START_TAG, ns, NODE_ELEMENT);
|
||||||
|
|
||||||
OCShare share = new OCShare();
|
OCShare share = new OCShare();
|
||||||
@ -270,7 +271,12 @@ public class ShareXMLParser {
|
|||||||
|
|
||||||
String name = parser.getName();
|
String name = parser.getName();
|
||||||
|
|
||||||
if (name.equalsIgnoreCase(NODE_ID)) {
|
if (name.equalsIgnoreCase(NODE_ELEMENT)) {
|
||||||
|
// patch to work around servers responding with extra <element> surrounding all the shares on the same file before
|
||||||
|
// https://github.com/owncloud/core/issues/6992 was fixed
|
||||||
|
readElement(parser, shares);
|
||||||
|
|
||||||
|
} else if (name.equalsIgnoreCase(NODE_ID)) {
|
||||||
share.setIdRemoteShared(Integer.parseInt(readNode(parser, NODE_ID)));
|
share.setIdRemoteShared(Integer.parseInt(readNode(parser, NODE_ID)));
|
||||||
|
|
||||||
} else if (name.equalsIgnoreCase(NODE_ITEM_TYPE)) {
|
} else if (name.equalsIgnoreCase(NODE_ITEM_TYPE)) {
|
||||||
@ -325,7 +331,15 @@ public class ShareXMLParser {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return share;
|
if (isValidShare(share)) {
|
||||||
|
shares.add(share);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isValidShare(OCShare share) {
|
||||||
|
return ((share.getIdRemoteShared() > -1) &&
|
||||||
|
(share.getShareType() == ShareType.PUBLIC_LINK) // at this moment we only care about public shares
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void fixPathForFolder(OCShare share) {
|
private void fixPathForFolder(OCShare share) {
|
||||||
|
@ -54,8 +54,6 @@ public class GetRemoteStatusOperation extends RemoteOperation {
|
|||||||
|
|
||||||
private static final String TAG = GetRemoteStatusOperation.class.getSimpleName();
|
private static final String TAG = GetRemoteStatusOperation.class.getSimpleName();
|
||||||
|
|
||||||
private static final String OCVERSION_SHARED_SUPPORTED = "5.0.13";
|
|
||||||
|
|
||||||
private static final String NODE_INSTALLED = "installed";
|
private static final String NODE_INSTALLED = "installed";
|
||||||
private static final String NODE_VERSION = "version";
|
private static final String NODE_VERSION = "version";
|
||||||
private static final String NODE_VERSIONSTRING = "versionstring";
|
private static final String NODE_VERSIONSTRING = "versionstring";
|
||||||
@ -64,27 +62,16 @@ public class GetRemoteStatusOperation extends RemoteOperation {
|
|||||||
private RemoteOperationResult mLatestResult;
|
private RemoteOperationResult mLatestResult;
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
private OwnCloudVersion mOCVersion;
|
private OwnCloudVersion mOCVersion;
|
||||||
private OwnCloudVersion mOCVersionString;
|
|
||||||
|
|
||||||
public GetRemoteStatusOperation(String url, Context context) {
|
public GetRemoteStatusOperation(String url, Context context) {
|
||||||
mUrl = url;
|
mUrl = url;
|
||||||
mContext = context;
|
mContext = context;
|
||||||
mOCVersion = null;
|
mOCVersion = null;
|
||||||
mOCVersionString = null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public OwnCloudVersion getDiscoveredVersion() {
|
public OwnCloudVersion getDiscoveredVersion() {
|
||||||
return mOCVersion;
|
return mOCVersion;
|
||||||
}
|
}
|
||||||
public boolean isSharedSupported() {
|
|
||||||
OwnCloudVersion shareServer = new OwnCloudVersion(OCVERSION_SHARED_SUPPORTED);
|
|
||||||
if (mOCVersionString != null) {
|
|
||||||
return mOCVersionString.compareTo(shareServer) >= 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean tryConnection(OwnCloudClient wc, String urlSt) {
|
private boolean tryConnection(OwnCloudClient wc, String urlSt) {
|
||||||
boolean retval = false;
|
boolean retval = false;
|
||||||
@ -98,8 +85,9 @@ public class GetRemoteStatusOperation extends RemoteOperation {
|
|||||||
if (!json.getBoolean(NODE_INSTALLED)) {
|
if (!json.getBoolean(NODE_INSTALLED)) {
|
||||||
mLatestResult = new RemoteOperationResult(RemoteOperationResult.ResultCode.INSTANCE_NOT_CONFIGURED);
|
mLatestResult = new RemoteOperationResult(RemoteOperationResult.ResultCode.INSTANCE_NOT_CONFIGURED);
|
||||||
} else {
|
} else {
|
||||||
mOCVersion = new OwnCloudVersion(json.getString(NODE_VERSION));
|
String version = json.getString(NODE_VERSION);
|
||||||
mOCVersionString = new OwnCloudVersion(json.getString(NODE_VERSIONSTRING), true);
|
String versionString = json.getString(NODE_VERSIONSTRING);
|
||||||
|
mOCVersion = new OwnCloudVersion(version, versionString);
|
||||||
if (!mOCVersion.isVersionValid()) {
|
if (!mOCVersion.isVersionValid()) {
|
||||||
mLatestResult = new RemoteOperationResult(RemoteOperationResult.ResultCode.BAD_OC_VERSION);
|
mLatestResult = new RemoteOperationResult(RemoteOperationResult.ResultCode.BAD_OC_VERSION);
|
||||||
|
|
||||||
|
@ -37,33 +37,33 @@ public class OwnCloudVersion implements Comparable<OwnCloudVersion> {
|
|||||||
public static final OwnCloudVersion owncloud_v4_5 = new OwnCloudVersion(
|
public static final OwnCloudVersion owncloud_v4_5 = new OwnCloudVersion(
|
||||||
0x040500);
|
0x040500);
|
||||||
|
|
||||||
|
public static final int MINIMUM_VERSION_STRING_FOR_SHARING_API = 0x05000D;
|
||||||
|
|
||||||
// format is in version
|
// format is in version
|
||||||
// 0xAABBCC
|
// 0xAABBCC
|
||||||
// for version AA.BB.CC
|
// for version AA.BB.CC
|
||||||
// ie version 2.0.3 will be stored as 0x030003
|
// ie version 2.0.3 will be stored as 0x020003
|
||||||
private int mVersion;
|
private int mVersion;
|
||||||
private boolean mIsValid;
|
private boolean mIsValid;
|
||||||
|
// not parsed, saved same value offered by the server
|
||||||
|
private String mVersionString;
|
||||||
|
|
||||||
public OwnCloudVersion(int version) {
|
protected OwnCloudVersion(int version) {
|
||||||
mVersion = version;
|
mVersion = version;
|
||||||
mIsValid = true;
|
mIsValid = true;
|
||||||
|
mVersionString = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
public OwnCloudVersion(String version) {
|
public OwnCloudVersion(String version, String versionString) {
|
||||||
mVersion = 0;
|
mVersion = 0;
|
||||||
mIsValid = false;
|
mIsValid = false;
|
||||||
parseVersionString(version);
|
parseVersionString(version);
|
||||||
}
|
if (versionString != null && versionString.length() > 0) {
|
||||||
|
mVersionString = versionString;
|
||||||
|
|
||||||
public OwnCloudVersion(String versionstring, boolean isVersionString) {
|
} else if (mIsValid) {
|
||||||
mVersion = 0;
|
mVersionString = version;
|
||||||
mIsValid = false;
|
|
||||||
if (isVersionString) {
|
|
||||||
parseVersionString(versionstring);
|
|
||||||
} else {
|
|
||||||
parseVersion(versionstring);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String toString() {
|
public String toString() {
|
||||||
@ -71,6 +71,14 @@ public class OwnCloudVersion implements Comparable<OwnCloudVersion> {
|
|||||||
+ ((mVersion) % 256);
|
+ ((mVersion) % 256);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getVersion() {
|
||||||
|
return toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getVersionString() {
|
||||||
|
return mVersionString;
|
||||||
|
}
|
||||||
|
|
||||||
public boolean isVersionValid() {
|
public boolean isVersionValid() {
|
||||||
return mIsValid;
|
return mIsValid;
|
||||||
}
|
}
|
||||||
@ -81,45 +89,48 @@ public class OwnCloudVersion implements Comparable<OwnCloudVersion> {
|
|||||||
: another.mVersion < mVersion ? 1 : -1;
|
: another.mVersion < mVersion ? 1 : -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void parseVersion(String version) {
|
private void parseVersionString(String versionString) {
|
||||||
try {
|
try {
|
||||||
String[] nums = version.split("\\.");
|
mVersion = getParsedVersionString(versionString);
|
||||||
if (nums.length > 0) {
|
|
||||||
mVersion += Integer.parseInt(nums[0]);
|
|
||||||
}
|
|
||||||
mVersion = mVersion << 8;
|
|
||||||
if (nums.length > 1) {
|
|
||||||
mVersion += Integer.parseInt(nums[1]);
|
|
||||||
}
|
|
||||||
mVersion = mVersion << 8;
|
|
||||||
if (nums.length > 2) {
|
|
||||||
mVersion += Integer.parseInt(nums[2]);
|
|
||||||
}
|
|
||||||
mIsValid = true;
|
mIsValid = true;
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
mIsValid = false;
|
mIsValid = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void parseVersionString(String versionstring) {
|
private int getParsedVersionString(String versionString) throws NumberFormatException {
|
||||||
try {
|
int version = 0;
|
||||||
versionstring = versionstring.replaceAll("[^\\d.]", "");
|
|
||||||
|
|
||||||
String[] nums = versionstring.split("\\.");
|
// get only numeric part
|
||||||
|
versionString = versionString.replaceAll("[^\\d.]", "");
|
||||||
|
|
||||||
|
String[] nums = versionString.split("\\.");
|
||||||
if (nums.length > 0) {
|
if (nums.length > 0) {
|
||||||
mVersion += Integer.parseInt(nums[0]);
|
version += Integer.parseInt(nums[0]);
|
||||||
}
|
}
|
||||||
mVersion = mVersion << 8;
|
version = version << 8;
|
||||||
if (nums.length > 1) {
|
if (nums.length > 1) {
|
||||||
mVersion += Integer.parseInt(nums[1]);
|
version += Integer.parseInt(nums[1]);
|
||||||
}
|
}
|
||||||
mVersion = mVersion << 8;
|
version = version << 8;
|
||||||
if (nums.length > 2) {
|
if (nums.length > 2) {
|
||||||
mVersion += Integer.parseInt(nums[2]);
|
version += Integer.parseInt(nums[2]);
|
||||||
}
|
}
|
||||||
mIsValid = true;
|
return version;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public boolean isSharedSupported() {
|
||||||
|
int versionString = 0;
|
||||||
|
try {
|
||||||
|
versionString = getParsedVersionString(mVersionString);
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
mIsValid = false;
|
// nothing to do here
|
||||||
}
|
}
|
||||||
|
return (versionString >= MINIMUM_VERSION_STRING_FOR_SHARING_API);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -80,10 +80,10 @@ public class GetRemoteUserNameOperation extends RemoteOperation {
|
|||||||
|
|
||||||
//Get the user
|
//Get the user
|
||||||
try {
|
try {
|
||||||
//GetMethod get = new GetMethod(client.getWebdavUri() + OCS_ROUTE);
|
get = new GetMethod(client.getWebdavUri() + OCS_ROUTE);
|
||||||
get = new GetMethod(client.getBaseUri() + OCS_ROUTE);
|
//get = new GetMethod(client.getBaseUri() + OCS_ROUTE); // need to fix the semantics of getBaseUri and getWebdavUri
|
||||||
Log.e(TAG, "Getting OC user information from " + client.getBaseUri() + OCS_ROUTE);
|
//Log.e(TAG, "Getting OC user information from " + client.getBaseUri() + OCS_ROUTE);
|
||||||
Log.e(TAG, "Getting OC user information from " + client.getWebdavUri() + OCS_ROUTE);
|
//Log.e(TAG, "Getting OC user information from " + client.getWebdavUri() + OCS_ROUTE);
|
||||||
// Add the Header
|
// Add the Header
|
||||||
get.addRequestHeader(HEADER_OCS_API, HEADER_OCS_API_VALUE);
|
get.addRequestHeader(HEADER_OCS_API, HEADER_OCS_API_VALUE);
|
||||||
status = client.executeMethod(get);
|
status = client.executeMethod(get);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user