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
42 public class CopyMethodImpl implements Method {
43
44 public int process(WebDAVRequest webDavRequest) throws WebDAVException {
45 WebDAVStorage storage = webDavRequest.getWebDAVStorage();
46 HttpServletRequest request = webDavRequest.getHttpServletRequest();
47
48 String destination = WebDAVUtil.getDestination(
49 request, storage.getRootPath());
50
51 StringBuilder sb = new StringBuilder();
52
53 if (_log.isInfoEnabled()) {
54 sb.append("Destination is " + destination);
55 }
56
57 int status = HttpServletResponse.SC_FORBIDDEN;
58
59 if ((!destination.equals(webDavRequest.getPath())) &&
60 (WebDAVUtil.getGroupId(destination) ==
61 webDavRequest.getGroupId())) {
62
63 Resource resource = storage.getResource(webDavRequest);
64
65 if (resource == null) {
66 status = HttpServletResponse.SC_NOT_FOUND;
67 }
68 else if (resource.isCollection()) {
69 boolean overwrite = WebDAVUtil.isOverwrite(request);
70 long depth = WebDAVUtil.getDepth(request);
71
72 if (_log.isInfoEnabled()) {
73 sb.append(", overwrite is " + overwrite);
74 sb.append(", depth is " + depth);
75
76 _log.info(sb.toString());
77 }
78
79 status = storage.copyCollectionResource(
80 webDavRequest, resource, destination, overwrite, depth);
81 }
82 else {
83 boolean overwrite = WebDAVUtil.isOverwrite(request);
84
85 if (_log.isInfoEnabled()) {
86 sb.append(", overwrite is " + overwrite);
87
88 _log.info(sb.toString());
89 }
90
91 status = storage.copySimpleResource(
92 webDavRequest, resource, destination, overwrite);
93 }
94 }
95
96 return status;
97 }
98
99 private static Log _log = LogFactoryUtil.getLog(CopyMethodImpl.class);
100
101 }