001
014
015 package com.liferay.portal.webdav.methods;
016
017 import com.liferay.portal.kernel.log.Log;
018 import com.liferay.portal.kernel.log.LogFactoryUtil;
019 import com.liferay.portal.kernel.util.StringBundler;
020 import com.liferay.portal.kernel.webdav.Resource;
021 import com.liferay.portal.kernel.webdav.WebDAVException;
022 import com.liferay.portal.kernel.webdav.WebDAVRequest;
023 import com.liferay.portal.kernel.webdav.WebDAVStorage;
024 import com.liferay.portal.kernel.webdav.WebDAVUtil;
025
026 import javax.servlet.http.HttpServletRequest;
027 import javax.servlet.http.HttpServletResponse;
028
029
033 public class MoveMethodImpl implements Method {
034
035 @Override
036 public int process(WebDAVRequest webDAVRequest) throws WebDAVException {
037 WebDAVStorage storage = webDAVRequest.getWebDAVStorage();
038 HttpServletRequest request = webDAVRequest.getHttpServletRequest();
039
040 long companyId = webDAVRequest.getCompanyId();
041 String destination = WebDAVUtil.getDestination(
042 request, storage.getRootPath());
043
044 StringBundler sb = new StringBundler();
045
046 if (_log.isInfoEnabled()) {
047 sb.append("Destination is ");
048 sb.append(destination);
049 }
050
051 if (!destination.equals(webDAVRequest.getPath()) &&
052 (WebDAVUtil.getGroupId(companyId, destination) ==
053 webDAVRequest.getGroupId())) {
054
055 Resource resource = storage.getResource(webDAVRequest);
056
057 if (resource == null) {
058 return HttpServletResponse.SC_NOT_FOUND;
059 }
060
061 boolean overwrite = WebDAVUtil.isOverwrite(request);
062
063 if (_log.isInfoEnabled()) {
064 sb.append(", overwrite is ");
065 sb.append(overwrite);
066
067 _log.info(sb.toString());
068 }
069
070 if (resource.isCollection()) {
071 return storage.moveCollectionResource(
072 webDAVRequest, resource, destination, overwrite);
073 }
074 else {
075 return storage.moveSimpleResource(
076 webDAVRequest, resource, destination, overwrite);
077 }
078 }
079
080 return HttpServletResponse.SC_FORBIDDEN;
081 }
082
083 private static Log _log = LogFactoryUtil.getLog(MoveMethodImpl.class);
084
085 }