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