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 import com.liferay.portal.kernel.webdav.methods.Method;
026
027 import javax.servlet.http.HttpServletRequest;
028 import javax.servlet.http.HttpServletResponse;
029
030
034 public class CopyMethodImpl implements Method {
035
036 @Override
037 public int process(WebDAVRequest webDAVRequest) throws WebDAVException {
038 WebDAVStorage storage = webDAVRequest.getWebDAVStorage();
039 HttpServletRequest request = webDAVRequest.getHttpServletRequest();
040
041 long companyId = webDAVRequest.getCompanyId();
042 String destination = WebDAVUtil.getDestination(
043 request, storage.getRootPath());
044
045 StringBundler sb = null;
046
047 if (_log.isInfoEnabled()) {
048 sb = new StringBundler(6);
049
050 sb.append("Destination is ");
051 sb.append(destination);
052 }
053
054 if (!destination.equals(webDAVRequest.getPath()) &&
055 (WebDAVUtil.getGroupId(companyId, destination) ==
056 webDAVRequest.getGroupId())) {
057
058 Resource resource = storage.getResource(webDAVRequest);
059
060 if (resource == null) {
061 return HttpServletResponse.SC_NOT_FOUND;
062 }
063
064 if (resource.isCollection()) {
065 boolean overwrite = WebDAVUtil.isOverwrite(request);
066 long depth = WebDAVUtil.getDepth(request);
067
068 if (_log.isInfoEnabled()) {
069 sb.append(", overwrite is ");
070 sb.append(overwrite);
071 sb.append(", depth is ");
072 sb.append(depth);
073
074 _log.info(sb.toString());
075 }
076
077 return storage.copyCollectionResource(
078 webDAVRequest, resource, destination, overwrite, depth);
079 }
080
081 boolean overwrite = WebDAVUtil.isOverwrite(request);
082
083 if (_log.isInfoEnabled()) {
084 sb.append(", overwrite is ");
085 sb.append(overwrite);
086
087 _log.info(sb.toString());
088 }
089
090 return storage.copySimpleResource(
091 webDAVRequest, resource, destination, overwrite);
092 }
093
094 return HttpServletResponse.SC_FORBIDDEN;
095 }
096
097 private static final Log _log = LogFactoryUtil.getLog(CopyMethodImpl.class);
098
099 }