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