import sys
import warnings
from cgi import escape
+from urllib import unquote
from OFS import Moniker
from ZODB.POSException import ConflictError
import OFS.subscribers
"""
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', '')
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 : 'Not implemented'
+
RESPONSE.setStatus(httpRespCode)
RESPONSE.setHeader('Content-Type', 'text/xml;;charset=utf-8')
- return '<fragment><![CDATA[%s]]></fragment>' % meth()
+ return '<fragment>%s</fragment>' % meth(ob).strip()
# ## overload to maintain ownership if authenticated user has 'Manage portal' permission