Removed usused drawable; list_selector rewritten from scratch with new license (and...
[pub/Android/ownCloud.git] / src / eu / alefzero / webdav / WebdavClient.java
index abd7048..1319a2b 100644 (file)
@@ -1,9 +1,10 @@
 /* ownCloud Android client application\r
  *   Copyright (C) 2011  Bartek Przybylski\r
 /* ownCloud Android client application\r
  *   Copyright (C) 2011  Bartek Przybylski\r
+ *   Copyright (C) 2012-2013 ownCloud Inc.\r
  *\r
  *   This program is free software: you can redistribute it and/or modify\r
  *   it under the terms of the GNU General Public License as published by\r
  *\r
  *   This program is free software: you can redistribute it and/or modify\r
  *   it under the terms of the GNU General Public License as published by\r
- *   the Free Software Foundation, either version 3 of the License, or\r
+ *   the Free Software Foundation, either version 2 of the License, or\r
  *   (at your option) any later version.\r
  *\r
  *   This program is distributed in the hope that it will be useful,\r
  *   (at your option) any later version.\r
  *\r
  *   This program is distributed in the hope that it will be useful,\r
@@ -98,15 +99,15 @@ public class WebdavClient extends HttpClient {
                 int readResult;\r
                 while ((readResult = bis.read(bytes)) != -1) {\r
                     if (mDataTransferListener != null)\r
                 int readResult;\r
                 while ((readResult = bis.read(bytes)) != -1) {\r
                     if (mDataTransferListener != null)\r
-                        mDataTransferListener.transferProgress(readResult);\r
+                        mDataTransferListener.onTransferProgress(readResult);\r
                     fos.write(bytes, 0, readResult);\r
                 }\r
                     fos.write(bytes, 0, readResult);\r
                 }\r
+                fos.close();\r
                 ret = true;\r
             } else {\r
                 exhaustResponse(get.getResponseBodyAsStream());\r
             }\r
             Log.e(TAG, "Download of " + remoteFilePath + " to " + targetFile + " finished with HTTP status " + status + (!ret?"(FAIL)":""));\r
                 ret = true;\r
             } else {\r
                 exhaustResponse(get.getResponseBodyAsStream());\r
             }\r
             Log.e(TAG, "Download of " + remoteFilePath + " to " + targetFile + " finished with HTTP status " + status + (!ret?"(FAIL)":""));\r
-            \r
         } catch (Exception e) {\r
             logException(e, "dowloading " + remoteFilePath);\r
             \r
         } catch (Exception e) {\r
             logException(e, "dowloading " + remoteFilePath);\r
             \r
@@ -151,39 +152,32 @@ public class WebdavClient extends HttpClient {
     /**\r
      * Creates or update a file in the remote server with the contents of a local file.\r
      * \r
     /**\r
      * Creates or update a file in the remote server with the contents of a local file.\r
      * \r
-     * \r
      * @param localFile         Path to the local file to upload.\r
      * @param remoteTarget      Remote path to the file to create or update, URL DECODED\r
      * @param contentType       MIME type of the file.\r
      * @param localFile         Path to the local file to upload.\r
      * @param remoteTarget      Remote path to the file to create or update, URL DECODED\r
      * @param contentType       MIME type of the file.\r
-     * @return                  'True' then the upload was successfully completed\r
+     * @return                  Status HTTP code returned by the server.\r
+     * @throws IOException      When a transport error that could not be recovered occurred while uploading the file to the server.\r
+     * @throws HttpException    When a violation of the HTTP protocol occurred. \r
      */\r
      */\r
-    public boolean putFile(String localFile, String remoteTarget, String contentType) {\r
-        boolean result = false;\r
+    public int putFile(String localFile, String remoteTarget, String contentType) throws HttpException, IOException {\r
         int status = -1;\r
         PutMethod put = new PutMethod(mUri.toString() + WebdavUtils.encodePath(remoteTarget));\r
         \r
         try {\r
             File f = new File(localFile);\r
             FileRequestEntity entity = new FileRequestEntity(f, contentType);\r
         int status = -1;\r
         PutMethod put = new PutMethod(mUri.toString() + WebdavUtils.encodePath(remoteTarget));\r
         \r
         try {\r
             File f = new File(localFile);\r
             FileRequestEntity entity = new FileRequestEntity(f, contentType);\r
-            entity.setOnDatatransferProgressListener(mDataTransferListener);\r
+            entity.addOnDatatransferProgressListener(mDataTransferListener);\r
             put.setRequestEntity(entity);\r
             status = executeMethod(put);\r
             \r
             put.setRequestEntity(entity);\r
             status = executeMethod(put);\r
             \r
-            result = (status == HttpStatus.SC_OK || status == HttpStatus.SC_CREATED || status == HttpStatus.SC_NO_CONTENT);\r
-            \r
-            Log.d(TAG, "PUT to " + remoteTarget + " finished with HTTP status " + status + (!result?"(FAIL)":""));\r
-\r
             exhaustResponse(put.getResponseBodyAsStream());\r
             \r
             exhaustResponse(put.getResponseBodyAsStream());\r
             \r
-        } catch (Exception e) {\r
-            logException(e, "uploading " + localFile + " to " + remoteTarget);\r
-            \r
         } finally {\r
             put.releaseConnection();    // let the connection available for other methods\r
         }\r
         } finally {\r
             put.releaseConnection();    // let the connection available for other methods\r
         }\r
-        return result;\r
+        return status;\r
     }\r
     }\r
-\r
+    \r
     /**\r
      * Tries to log in to the current URI, with the current credentials\r
      * \r
     /**\r
      * Tries to log in to the current URI, with the current credentials\r
      * \r
@@ -239,9 +233,10 @@ public class WebdavClient extends HttpClient {
     /**\r
      * Check if a file exists in the OC server\r
      * \r
     /**\r
      * Check if a file exists in the OC server\r
      * \r
-     * @return      'Boolean.TRUE' if the file exists; 'Boolean.FALSE' it doesn't exist; NULL if couldn't be checked\r
+     * @return              'true' if the file exists; 'false' it doesn't exist\r
+     * @throws  Exception   When the existence could not be determined\r
      */\r
      */\r
-    public Boolean existsFile(String path) {\r
+    public boolean existsFile(String path) throws IOException, HttpException {\r
         HeadMethod head = new HeadMethod(mUri.toString() + WebdavUtils.encodePath(path));\r
         try {\r
             int status = executeMethod(head);\r
         HeadMethod head = new HeadMethod(mUri.toString() + WebdavUtils.encodePath(path));\r
         try {\r
             int status = executeMethod(head);\r
@@ -249,10 +244,6 @@ public class WebdavClient extends HttpClient {
             exhaustResponse(head.getResponseBodyAsStream());\r
             return (status == HttpStatus.SC_OK);\r
             \r
             exhaustResponse(head.getResponseBodyAsStream());\r
             return (status == HttpStatus.SC_OK);\r
             \r
-        } catch (Exception e) {\r
-            logException(e, "checking existence of " + path);\r
-            return null;\r
-            \r
         } finally {\r
             head.releaseConnection();    // let the connection available for other methods\r
         }\r
         } finally {\r
             head.releaseConnection();    // let the connection available for other methods\r
         }\r
@@ -295,7 +286,7 @@ public class WebdavClient extends HttpClient {
      * \r
      * @param responseBodyAsStream      InputStream with the HTTP response to exhaust.\r
      */\r
      * \r
      * @param responseBodyAsStream      InputStream with the HTTP response to exhaust.\r
      */\r
-    private static void exhaustResponse(InputStream responseBodyAsStream) {\r
+    public void exhaustResponse(InputStream responseBodyAsStream) {\r
         if (responseBodyAsStream != null) {\r
             try {\r
                 while (responseBodyAsStream.read(sExhaustBuffer) >= 0);\r
         if (responseBodyAsStream != null) {\r
             try {\r
                 while (responseBodyAsStream.read(sExhaustBuffer) >= 0);\r
@@ -314,7 +305,7 @@ public class WebdavClient extends HttpClient {
      * @param e         Caught exception.\r
      * @param doing     Suffix to add at the end of the logged message.\r
      */\r
      * @param e         Caught exception.\r
      * @param doing     Suffix to add at the end of the logged message.\r
      */\r
-    private static void logException(Exception e, String doing) {\r
+    private void logException(Exception e, String doing) {\r
         if (e instanceof HttpException) {\r
             Log.e(TAG, "HTTP violation while " + doing, e);\r
 \r
         if (e instanceof HttpException) {\r
             Log.e(TAG, "HTTP violation while " + doing, e);\r
 \r
@@ -342,5 +333,9 @@ public class WebdavClient extends HttpClient {
     public void setBaseUri(Uri uri) {\r
         mUri = uri;\r
     }\r
     public void setBaseUri(Uri uri) {\r
         mUri = uri;\r
     }\r
-    \r
+\r
+    public Uri getBaseUri() {\r
+        return mUri;\r
+    }\r
+\r
 }\r
 }\r