mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-21 18:09:20 +00:00
Sharepoint [MS-WDVMODUU]: implemented WebDAV PUT method.
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@38232 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -35,6 +35,7 @@ import org.alfresco.service.cmr.repository.ContentWriter;
|
|||||||
import org.alfresco.service.cmr.repository.NodeRef;
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
import org.alfresco.service.cmr.webdav.WebDavService;
|
import org.alfresco.service.cmr.webdav.WebDavService;
|
||||||
import org.springframework.dao.ConcurrencyFailureException;
|
import org.springframework.dao.ConcurrencyFailureException;
|
||||||
|
import org.springframework.extensions.surf.util.URLDecoder;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Implements the WebDAV PUT method
|
* Implements the WebDAV PUT method
|
||||||
@@ -110,7 +111,7 @@ public class PutMethod extends WebDAVMethod implements ActivityPostProducer
|
|||||||
FileInfo contentNodeInfo = null;
|
FileInfo contentNodeInfo = null;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
contentNodeInfo = getDAVHelper().getNodeForPath(getRootNodeRef(), getPath(), getServletPath());
|
contentNodeInfo = getNodeForPath(getRootNodeRef(), getPath(), getServletPath());
|
||||||
checkNode(contentNodeInfo);
|
checkNode(contentNodeInfo);
|
||||||
final NodeRef nodeRef = contentNodeInfo.getNodeRef();
|
final NodeRef nodeRef = contentNodeInfo.getNodeRef();
|
||||||
if (getNodeService().hasAspect(contentNodeInfo.getNodeRef(), ContentModel.ASPECT_WEBDAV_NO_CONTENT))
|
if (getNodeService().hasAspect(contentNodeInfo.getNodeRef(), ContentModel.ASPECT_WEBDAV_NO_CONTENT))
|
||||||
@@ -155,7 +156,7 @@ public class PutMethod extends WebDAVMethod implements ActivityPostProducer
|
|||||||
// Get the status for the request path
|
// Get the status for the request path
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
contentNodeInfo = getDAVHelper().getNodeForPath(getRootNodeRef(), getPath(), getServletPath());
|
contentNodeInfo = getNodeForPath(getRootNodeRef(), getPath(), getServletPath());
|
||||||
// make sure that we are not trying to use a folder
|
// make sure that we are not trying to use a folder
|
||||||
if (contentNodeInfo.isFolder())
|
if (contentNodeInfo.isFolder())
|
||||||
{
|
{
|
||||||
@@ -171,7 +172,7 @@ public class PutMethod extends WebDAVMethod implements ActivityPostProducer
|
|||||||
String[] paths = getDAVHelper().splitPath(getPath());
|
String[] paths = getDAVHelper().splitPath(getPath());
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
FileInfo parentNodeInfo = getDAVHelper().getNodeForPath(getRootNodeRef(), paths[0], getServletPath());
|
FileInfo parentNodeInfo = getNodeForPath(getRootNodeRef(), paths[0], getServletPath());
|
||||||
// create file
|
// create file
|
||||||
contentNodeInfo = fileFolderService.create(parentNodeInfo.getNodeRef(), paths[1], ContentModel.TYPE_CONTENT);
|
contentNodeInfo = fileFolderService.create(parentNodeInfo.getNodeRef(), paths[1], ContentModel.TYPE_CONTENT);
|
||||||
created = true;
|
created = true;
|
||||||
@@ -334,7 +335,7 @@ public class PutMethod extends WebDAVMethod implements ActivityPostProducer
|
|||||||
*
|
*
|
||||||
* @throws WebDAVServerException
|
* @throws WebDAVServerException
|
||||||
*/
|
*/
|
||||||
private void postActivity() throws WebDAVServerException
|
protected void postActivity() throws WebDAVServerException
|
||||||
{
|
{
|
||||||
WebDavService davService = getDAVHelper().getServiceRegistry().getWebDavService();
|
WebDavService davService = getDAVHelper().getServiceRegistry().getWebDavService();
|
||||||
if (!davService.activitiesEnabled())
|
if (!davService.activitiesEnabled())
|
||||||
@@ -356,7 +357,7 @@ public class PutMethod extends WebDAVMethod implements ActivityPostProducer
|
|||||||
FileInfo contentNodeInfo = null;
|
FileInfo contentNodeInfo = null;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
contentNodeInfo = getDAVHelper().getNodeForPath(getRootNodeRef(), path, getServletPath());
|
contentNodeInfo = getNodeForPath(getRootNodeRef(), path, getServletPath());
|
||||||
NodeRef nodeRef = contentNodeInfo.getNodeRef();
|
NodeRef nodeRef = contentNodeInfo.getNodeRef();
|
||||||
// Don't post activity data for hidden files, resource forks etc.
|
// Don't post activity data for hidden files, resource forks etc.
|
||||||
if (!getNodeService().hasAspect(nodeRef, ContentModel.ASPECT_HIDDEN))
|
if (!getNodeService().hasAspect(nodeRef, ContentModel.ASPECT_HIDDEN))
|
||||||
|
Reference in New Issue
Block a user