X-Git-Url: https://scm.cri.ensmp.fr/git/Plinn.git/blobdiff_plain/a9e61f8d7e3ef299e47f6e2cefc7ced4b252c94b..9bd0dc7c3396bc90f5cef31a77b67db283fd12b8:/Folder.py
diff --git a/Folder.py b/Folder.py
index 9051b3c..9b30e53 100644
--- a/Folder.py
+++ b/Folder.py
@@ -31,6 +31,7 @@ from zExceptions import Unauthorized
import sys
import warnings
from cgi import escape
+from urllib import unquote
from OFS import Moniker
from ZODB.POSException import ConflictError
import OFS.subscribers
@@ -57,6 +58,7 @@ from Products.CMFCore.utils import _checkPermission, getToolByName
from Products.CMFCore.utils import getUtilityByInterfaceName
from Products.CMFCore.CMFCatalogAware import CMFCatalogAware
from Products.CMFCore.PortalFolder import PortalFolder, ContentFilter
+from Products.CMFCore.interfaces import IDublinCore
from Products.CMFDefault.DublinCore import DefaultDublinCoreImpl
from zope.interface import implements
@@ -264,7 +266,9 @@ class PlinnFolder(CMFCatalogAware, PortalFolder, DefaultDublinCoreImpl) :
ctool = getUtilityByInterfaceName('Products.CMFCore.interfaces.ICatalogTool')
contentFilter['path'] = {'query':'/'.join(self.getPhysicalPath()),
'depth':1}
- return ctool(sort_on='position', **contentFilter)
+ if not contentFilter.has_key('sort_on') :
+ contentFilter['sort_index'] = 'position'
+ return ctool(**contentFilter)
security.declarePublic('synContentValues')
def synContentValues(self):
@@ -297,8 +301,7 @@ class PlinnFolder(CMFCatalogAware, PortalFolder, DefaultDublinCoreImpl) :
"""
self.dav__init(REQUEST, RESPONSE)
-
- fileName = REQUEST.getHeader('X-File-Name', '')
+ fileName = unquote(REQUEST.getHeader('X-File-Name', ''))
validId = makeValidId(self, fileName, allow_dup=True)
ifhdr = REQUEST.get_header('If', '')
@@ -322,9 +325,16 @@ class PlinnFolder(CMFCatalogAware, PortalFolder, DefaultDublinCoreImpl) :
typ, enc=guess_content_type(validId, body)
if self.checkIdAvailable(validId) :
- ob = self.PUT_factory(validId, typ, body)
- self._setObject(validId, ob)
- ob = self._getOb(validId)
+ try :
+ ob = self.PUT_factory(validId, typ, body)
+ self._setObject(validId, ob)
+ ob = self._getOb(validId)
+ except ValueError : # maybe "Disallowed subobject type". Fallback to file type.
+ validId = self.invokeFactory('File', validId)
+ ob = self._getOb(validId)
+ if IDublinCore.providedBy(ob) :
+ ob.editMetadata(title=fileName,
+ format=typ)
httpRespCode = 201
else :
httpRespCode = 200
@@ -343,13 +353,19 @@ class PlinnFolder(CMFCatalogAware, PortalFolder, DefaultDublinCoreImpl) :
ob.PUT(REQUEST, RESPONSE)
ob.orig_name = fileName
-
+ # get method from ob created / refreshed
ti = ob.getTypeInfo()
method_id = ti.queryMethodID('jsupload_snippet')
- meth = method_id and getattr(ob, method_id) or (lambda : 'Not implemented')
+ meth = getattr(ob, method_id) if method_id else None
+ if not meth :
+ # get method from container that receive uploaded content
+ ti = self.getTypeInfo()
+ method_id = ti.queryMethodID('jsupload_snippet')
+ meth = getattr(self, method_id) if method_id else lambda ob : 'Not implemented'
+
RESPONSE.setStatus(httpRespCode)
RESPONSE.setHeader('Content-Type', 'text/xml;;charset=utf-8')
- return '' % meth()
+ return '%s' % meth(ob).strip()
# ## overload to maintain ownership if authenticated user has 'Manage portal' permission