1
22
23 package com.liferay.portal.webdav.methods;
24
25 import com.liferay.portal.webdav.Resource;
26 import com.liferay.portal.webdav.WebDAVException;
27 import com.liferay.portal.webdav.WebDAVRequest;
28 import com.liferay.portal.webdav.WebDAVStorage;
29 import com.liferay.portal.webdav.WebDAVUtil;
30
31 import javax.servlet.http.HttpServletRequest;
32 import javax.servlet.http.HttpServletResponse;
33
34 import org.apache.commons.logging.Log;
35 import org.apache.commons.logging.LogFactory;
36
37
44 public class CopyMethodImpl implements Method {
45
46 public int process(WebDAVRequest webDavRequest) throws WebDAVException {
47 WebDAVStorage storage = webDavRequest.getWebDAVStorage();
48 HttpServletRequest request = webDavRequest.getHttpServletRequest();
49
50 String destination = WebDAVUtil.getDestination(
51 request, storage.getRootPath());
52
53 StringBuilder sb = new StringBuilder();
54
55 if (_log.isInfoEnabled()) {
56 sb.append("Destination is " + destination);
57 }
58
59 int status = HttpServletResponse.SC_FORBIDDEN;
60
61 if ((!destination.equals(webDavRequest.getPath())) &&
62 (WebDAVUtil.getGroupId(destination) ==
63 webDavRequest.getGroupId())) {
64
65 Resource resource = storage.getResource(webDavRequest);
66
67 if (resource == null) {
68 status = HttpServletResponse.SC_NOT_FOUND;
69 }
70 else if (resource.isCollection()) {
71 boolean overwrite = WebDAVUtil.isOverwrite(request);
72 long depth = WebDAVUtil.getDepth(request);
73
74 if (_log.isInfoEnabled()) {
75 sb.append(", overwrite is " + overwrite);
76 sb.append(", depth is " + depth);
77
78 _log.info(sb.toString());
79 }
80
81 status = storage.copyCollectionResource(
82 webDavRequest, resource, destination, overwrite, depth);
83 }
84 else {
85 boolean overwrite = WebDAVUtil.isOverwrite(request);
86
87 if (_log.isInfoEnabled()) {
88 sb.append(", overwrite is " + overwrite);
89
90 _log.info(sb.toString());
91 }
92
93 status = storage.copySimpleResource(
94 webDavRequest, resource, destination, overwrite);
95 }
96 }
97
98 return status;
99 }
100
101 private static Log _log = LogFactory.getLog(CopyMethodImpl.class);
102
103 }