[1] | 1 | from Products.CMFPlone.URLTool import URLTool |
---|
| 2 | |
---|
| 3 | from adapters.interfaces import IRequestPortalUrlAnnotator |
---|
| 4 | |
---|
[298] | 5 | ## XXX PATCH FOR FILERESOURCE, UNTILL ADD 'POST' METHOD OR FIX |
---|
| 6 | ## ResourceRegistries.tools.BaseRegistry.BaseRegistryTool.getResourceContent method |
---|
| 7 | marker = [] |
---|
| 8 | from Products.Five.browser.resource import FileResource |
---|
| 9 | |
---|
| 10 | if getattr(FileResource, 'POST', marker) == marker: |
---|
| 11 | FileResource.POST = FileResource.GET |
---|
| 12 | |
---|
[1] | 13 | def urltool_call(self, relative=0, *args, **kw): |
---|
| 14 | """ Get by default the absolute URL of the portal. If request is annonated then add suffix to portal_url |
---|
| 15 | """ |
---|
[66] | 16 | # print '################################ Called patched portal_url __call__: ' + self.REQUEST.URL |
---|
[1] | 17 | url_suffix = '' |
---|
| 18 | if self.REQUEST: |
---|
| 19 | annotator = IRequestPortalUrlAnnotator(self.REQUEST, None) |
---|
| 20 | if annotator is not None: |
---|
[503] | 21 | url_suffix = annotator.getPortalUrlSuffix(default=marker) |
---|
| 22 | if not url_suffix == marker: |
---|
| 23 | return url_suffix |
---|
[482] | 24 | return self.getPortalObject().absolute_url(relative=relative) |
---|
[1] | 25 | |
---|
[66] | 26 | def urltool_getPortalPath(self): |
---|
| 27 | """ Get the portal object's URL without the server URL component. |
---|
| 28 | """ |
---|
| 29 | |
---|
| 30 | url_suffix = '' |
---|
| 31 | if self.REQUEST: |
---|
| 32 | annotator = IRequestPortalUrlAnnotator(self.REQUEST, None) |
---|
| 33 | if annotator is not None: |
---|
| 34 | url_suffix = annotator.getPortalUrlSuffix() |
---|
| 35 | # print '############ Added sufix to portal_url: ' + url_suffix |
---|
| 36 | |
---|
| 37 | return '/'.join(self.getPortalObject().getPhysicalPath()) + url_suffix |
---|
| 38 | |
---|
| 39 | URLTool.__call__ = urltool_call |
---|
[298] | 40 | #URLTool.getPortalPath = urltool_getPortalPath |
---|