+ String SHARED_PATH = "/apps/files_sharing/get.php?token=";\r
+ \r
+ final String WEBDAV_SCRIPT = "webdav.php";\r
+ final String WEBDAV_FILES_LOCATION = "/files/";\r
+ \r
+ WebdavClient wc = new WebdavClient();\r
+ HttpConnectionManagerParams params = new HttpConnectionManagerParams();\r
+ params.setMaxConnectionsPerHost(wc.getHostConfiguration(), 5);\r
+\r
+ //wc.getParams().setParameter("http.protocol.single-cookie-header", true);\r
+ //wc.getParams().setCookiePolicy(CookiePolicy.BROWSER_COMPATIBILITY);\r
+\r
+ PostMethod post = new PostMethod(am.getUserData(account, AccountAuthenticator.KEY_OC_BASE_URL) + APPS_PATH + SHARE_PATH);\r
+\r
+ post.addRequestHeader("Content-type","application/x-www-form-urlencoded; charset=UTF-8" );\r
+ post.addRequestHeader("Referer", am.getUserData(account, AccountAuthenticator.KEY_OC_BASE_URL));\r
+ List<NameValuePair> formparams = new ArrayList<NameValuePair>();\r
+ Log.d("share", mPath+"");\r
+ formparams.add(new BasicNameValuePair("sources",mPath));\r
+ formparams.add(new BasicNameValuePair("uid_shared_with", "public"));\r
+ formparams.add(new BasicNameValuePair("permissions", "0"));\r
+ post.setRequestEntity(new StringRequestEntity(URLEncodedUtils.format(formparams, HTTP.UTF_8)));\r
+\r
+ int status;\r
+ try {\r
+ PropFindMethod find = new PropFindMethod(url+"/");\r
+ find.addRequestHeader("Referer", am.getUserData(account, AccountAuthenticator.KEY_OC_BASE_URL));\r
+ Log.d("sharer", ""+ url+"/");\r
+ wc.setCredentials(account.name.substring(0, account.name.lastIndexOf('@')), am.getPassword(account));\r
+ \r
+ for (org.apache.commons.httpclient.Header a : find.getRequestHeaders()) {\r
+ Log.d("sharer-h", a.getName() + ":"+a.getValue());\r
+ }\r
+ \r
+ int status2 = wc.executeMethod(find);\r
+\r
+ Log.d("sharer", "propstatus "+status2);\r
+ \r
+ GetMethod get = new GetMethod(am.getUserData(account, AccountAuthenticator.KEY_OC_BASE_URL) + "/");\r
+ get.addRequestHeader("Referer", am.getUserData(account, AccountAuthenticator.KEY_OC_BASE_URL));\r
+ \r
+ status2 = wc.executeMethod(get);\r
+\r
+ Log.d("sharer", "getstatus "+status2);\r
+ Log.d("sharer", "" + get.getResponseBodyAsString());\r
+ \r
+ for (org.apache.commons.httpclient.Header a : get.getResponseHeaders()) {\r
+ Log.d("sharer", a.getName() + ":"+a.getValue());\r
+ }\r
+\r
+ status = wc.executeMethod(post);\r
+ for (org.apache.commons.httpclient.Header a : post.getRequestHeaders()) {\r
+ Log.d("sharer-h", a.getName() + ":"+a.getValue());\r
+ }\r
+ for (org.apache.commons.httpclient.Header a : post.getResponseHeaders()) {\r
+ Log.d("sharer", a.getName() + ":"+a.getValue());\r
+ }\r
+ String resp = post.getResponseBodyAsString();\r
+ Log.d("share", ""+post.getURI().toString());\r
+ Log.d("share", "returned status " + status);\r
+ Log.d("share", " " +resp);\r
+ \r
+ if(status != HttpStatus.SC_OK ||resp == null || resp.equals("") || resp.startsWith("false")) {\r
+ return;\r
+ }\r
+\r
+ JSONObject jsonObject = new JSONObject (resp);\r
+ String jsonStatus = jsonObject.getString("status");\r
+ if(!jsonStatus.equals("success")) throw new Exception("Error while sharing file status != success");\r
+ \r
+ String token = jsonObject.getString("data");\r
+ String uri = am.getUserData(account, AccountAuthenticator.KEY_OC_BASE_URL) + SHARED_PATH + token; \r
+ Log.d("Actions:shareFile ok", "url: " + uri); \r
+ \r
+ } catch (HttpException e) {\r
+ // TODO Auto-generated catch block\r
+ e.printStackTrace();\r
+ } catch (IOException e) {\r
+ // TODO Auto-generated catch block\r
+ e.printStackTrace();\r
+ } catch (JSONException e) {\r
+ // TODO Auto-generated catch block\r
+ e.printStackTrace();\r
+ } catch (Exception e) {\r
+ // TODO Auto-generated catch block\r
+ e.printStackTrace();\r
+ }\r
+ \r
+ } else if (ocv.compareTo(new OwnCloudVersion(0x030000)) >= 0) {\r
+ \r
+ }\r
+ }\r
+ }\r
+ \r
+ public void onDismiss(EditNameFragment dialog) {\r
+ Log.e("ASD","ondismiss");\r
+ if (dialog instanceof EditNameFragment) {\r
+ if (((EditNameFragment)dialog).getResult()) {\r
+ String newFilename = ((EditNameFragment)dialog).getNewFilename();\r
+ Log.d(TAG, "name edit dialog dismissed with new name " + newFilename);\r
+ if (!newFilename.equals(mFile.getFileName())) {\r
+ FileDataStorageManager fdsm = new FileDataStorageManager(mAccount, getActivity().getContentResolver());\r
+ if (fdsm.getFileById(mFile.getFileId()) != null) {\r
+ OCFile newFile = new OCFile(fdsm.getFileById(mFile.getParentId()).getRemotePath()+"/"+newFilename);\r
+ newFile.setCreationTimestamp(mFile.getCreationTimestamp());\r
+ newFile.setFileId(mFile.getFileId());\r
+ newFile.setFileLength(mFile.getFileLength());\r
+ newFile.setKeepInSync(mFile.keepInSync());\r
+ newFile.setLastSyncDate(mFile.getLastSyncDate());\r
+ newFile.setMimetype(mFile.getMimetype());\r
+ newFile.setModificationTimestamp(mFile.getModificationTimestamp());\r
+ newFile.setParentId(mFile.getParentId());\r
+ newFile.setStoragePath(mFile.getStoragePath());\r
+ \r
+ new Thread(new RenameRunnable(mFile, newFile, mAccount, new Handler())).start();\r
+\r
+ }\r
+ }\r
+ }\r
+ } else {\r
+ Log.e(TAG, "Unknown dialog intance passed to onDismissDalog: " + dialog.getClass().getCanonicalName());\r
+ }\r
+ \r
+ }\r
+ \r
+ private class RenameRunnable implements Runnable {\r
+ \r
+ Account mAccount;\r
+ OCFile mOld, mNew;\r
+ Handler mHandler;\r
+ \r
+ public RenameRunnable(OCFile oldFile, OCFile newFile, Account account, Handler handler) {\r
+ mOld = oldFile;\r
+ mNew = newFile;\r
+ mAccount = account;\r
+ mHandler = handler;\r
+ }\r
+ \r
+ public void run() {\r
+ WebdavClient wc = new WebdavClient(mAccount, getSherlockActivity().getApplicationContext());\r
+ AccountManager am = AccountManager.get(getSherlockActivity());\r
+ String baseUrl = am.getUserData(mAccount, AccountAuthenticator.KEY_OC_BASE_URL);\r
+ OwnCloudVersion ocv = new OwnCloudVersion(am.getUserData(mAccount, AccountAuthenticator.KEY_OC_VERSION));\r
+ String webdav_path = AccountUtils.getWebdavPath(ocv);\r
+ Log.d("ASD", ""+baseUrl + webdav_path + mOld.getRemotePath());\r
+\r
+ Log.e("ASD", Uri.parse(baseUrl).getPath() == null ? "" : Uri.parse(baseUrl).getPath() + webdav_path + mNew.getRemotePath());\r
+ LocalMoveMethod move = new LocalMoveMethod(baseUrl + webdav_path + mOld.getRemotePath(),\r
+ Uri.parse(baseUrl).getPath() == null ? "" : Uri.parse(baseUrl).getPath() + webdav_path + mNew.getRemotePath());\r
+ \r
+ try {\r
+ int status = wc.executeMethod(move);\r
+ if (move.succeeded()) {\r
+ FileDataStorageManager fdsm = new FileDataStorageManager(mAccount, getActivity().getContentResolver());\r
+ fdsm.removeFile(mOld);\r
+ fdsm.saveFile(mNew);\r
+ mFile = mNew;\r
+ mHandler.post(new Runnable() {\r
+ @Override\r
+ public void run() { updateFileDetails(mFile, mAccount); }\r
+ });\r
+ }\r
+ Log.e("ASD", ""+move.getQueryString());\r
+ Log.d("move", "returned status " + status);\r
+ } catch (HttpException e) {\r
+ // TODO Auto-generated catch block\r
+ e.printStackTrace();\r
+ } catch (IOException e) {\r
+ // TODO Auto-generated catch block\r
+ e.printStackTrace();\r
+ }\r
+ }\r
+ private class LocalMoveMethod extends DavMethodBase {\r
+\r
+ public LocalMoveMethod(String uri, String dest) {\r
+ super(uri);\r
+ addRequestHeader(new org.apache.commons.httpclient.Header("Destination", dest));\r
+ }\r
+\r
+ @Override\r
+ public String getName() {\r
+ return "MOVE";\r
+ }\r
+\r
+ @Override\r
+ protected boolean isSuccess(int status) {\r
+ return status == 201 || status == 204;\r
+ }\r
+ \r
+ }\r