X-Git-Url: http://git.linex4red.de/pub/Android/ownCloud.git/blobdiff_plain/99d52af203f63a5dd3d43626f569ac88c5ac9b14..97dd59063ba1bf16fa2c176563614a9ce310b158:/src/eu/alefzero/webdav/WebdavClient.java?ds=inline diff --git a/src/eu/alefzero/webdav/WebdavClient.java b/src/eu/alefzero/webdav/WebdavClient.java index abd70489..61f16605 100644 --- a/src/eu/alefzero/webdav/WebdavClient.java +++ b/src/eu/alefzero/webdav/WebdavClient.java @@ -98,15 +98,15 @@ public class WebdavClient extends HttpClient { int readResult; while ((readResult = bis.read(bytes)) != -1) { if (mDataTransferListener != null) - mDataTransferListener.transferProgress(readResult); + mDataTransferListener.onTransferProgress(readResult); fos.write(bytes, 0, readResult); } + fos.close(); ret = true; } else { exhaustResponse(get.getResponseBodyAsStream()); } Log.e(TAG, "Download of " + remoteFilePath + " to " + targetFile + " finished with HTTP status " + status + (!ret?"(FAIL)":"")); - } catch (Exception e) { logException(e, "dowloading " + remoteFilePath); @@ -151,39 +151,32 @@ public class WebdavClient extends HttpClient { /** * Creates or update a file in the remote server with the contents of a local file. * - * * @param localFile Path to the local file to upload. * @param remoteTarget Remote path to the file to create or update, URL DECODED * @param contentType MIME type of the file. - * @return 'True' then the upload was successfully completed + * @return Status HTTP code returned by the server. + * @throws IOException When a transport error that could not be recovered occurred while uploading the file to the server. + * @throws HttpException When a violation of the HTTP protocol occurred. */ - public boolean putFile(String localFile, String remoteTarget, String contentType) { - boolean result = false; + public int putFile(String localFile, String remoteTarget, String contentType) throws HttpException, IOException { int status = -1; PutMethod put = new PutMethod(mUri.toString() + WebdavUtils.encodePath(remoteTarget)); try { File f = new File(localFile); FileRequestEntity entity = new FileRequestEntity(f, contentType); - entity.setOnDatatransferProgressListener(mDataTransferListener); + entity.addOnDatatransferProgressListener(mDataTransferListener); put.setRequestEntity(entity); status = executeMethod(put); - result = (status == HttpStatus.SC_OK || status == HttpStatus.SC_CREATED || status == HttpStatus.SC_NO_CONTENT); - - Log.d(TAG, "PUT to " + remoteTarget + " finished with HTTP status " + status + (!result?"(FAIL)":"")); - exhaustResponse(put.getResponseBodyAsStream()); - } catch (Exception e) { - logException(e, "uploading " + localFile + " to " + remoteTarget); - } finally { put.releaseConnection(); // let the connection available for other methods } - return result; + return status; } - + /** * Tries to log in to the current URI, with the current credentials * @@ -239,9 +232,10 @@ public class WebdavClient extends HttpClient { /** * Check if a file exists in the OC server * - * @return 'Boolean.TRUE' if the file exists; 'Boolean.FALSE' it doesn't exist; NULL if couldn't be checked + * @return 'true' if the file exists; 'false' it doesn't exist + * @throws Exception When the existence could not be determined */ - public Boolean existsFile(String path) { + public boolean existsFile(String path) throws IOException, HttpException { HeadMethod head = new HeadMethod(mUri.toString() + WebdavUtils.encodePath(path)); try { int status = executeMethod(head); @@ -249,10 +243,6 @@ public class WebdavClient extends HttpClient { exhaustResponse(head.getResponseBodyAsStream()); return (status == HttpStatus.SC_OK); - } catch (Exception e) { - logException(e, "checking existence of " + path); - return null; - } finally { head.releaseConnection(); // let the connection available for other methods } @@ -295,7 +285,7 @@ public class WebdavClient extends HttpClient { * * @param responseBodyAsStream InputStream with the HTTP response to exhaust. */ - private static void exhaustResponse(InputStream responseBodyAsStream) { + public void exhaustResponse(InputStream responseBodyAsStream) { if (responseBodyAsStream != null) { try { while (responseBodyAsStream.read(sExhaustBuffer) >= 0); @@ -314,7 +304,7 @@ public class WebdavClient extends HttpClient { * @param e Caught exception. * @param doing Suffix to add at the end of the logged message. */ - private static void logException(Exception e, String doing) { + private void logException(Exception e, String doing) { if (e instanceof HttpException) { Log.e(TAG, "HTTP violation while " + doing, e); @@ -342,5 +332,9 @@ public class WebdavClient extends HttpClient { public void setBaseUri(Uri uri) { mUri = uri; } - + + public Uri getBaseUri() { + return mUri; + } + }