src/pyams_default_theme/routes.py
changeset 284 aa70cb77cf43
parent 205 1b2e282d3cf2
child 352 2cdb8562f7fd
--- a/src/pyams_default_theme/routes.py	Fri Dec 07 16:14:03 2018 +0100
+++ b/src/pyams_default_theme/routes.py	Mon Dec 10 14:45:33 2018 +0100
@@ -12,19 +12,15 @@
 
 __docformat__ = 'restructuredtext'
 
-from hypatia.catalog import CatalogQuery
-from hypatia.interfaces import ICatalog
-from hypatia.query import Any, Eq
 from pyramid.exceptions import NotFound
 from pyramid.response import Response
 from pyramid.view import view_config
 
-from pyams_catalog.query import CatalogResultSet
-from pyams_content.workflow import VISIBLE_STATES
 from pyams_sequence.interfaces import ISequentialIntIds
+from pyams_sequence.reference import get_reference_target
 from pyams_utils.registry import get_utility
 from pyams_utils.url import absolute_url, canonical_url
-from pyams_workflow.interfaces import IWorkflowVersions
+from pyams_workflow.interfaces import IWorkflow, IWorkflowPublicationInfo, IWorkflowVersions
 
 
 @view_config(route_name='oid_access')
@@ -39,20 +35,24 @@
     if oid:
         view_name = request.matchdict.get('view')
         sequence = get_utility(ISequentialIntIds)
-        hex_oid = sequence.get_full_oid(oid)
-        catalog = get_utility(ICatalog)
-        params = Eq(catalog['oid'], hex_oid)
-        if not view_name:
-            params &= Any(catalog['workflow_state'], VISIBLE_STATES)
-        results = list(CatalogResultSet(CatalogQuery(catalog).query(params)))
-        if results:
+        reference = sequence.get_full_oid(oid)
+        target = get_reference_target(reference)
+        if target is not None:
+            workflow = IWorkflow(target, None)
+            if workflow is not None:
+                versions = IWorkflowVersions(target, None)
+                if versions is not None:
+                    versions = versions.get_versions(workflow.published_states, sort=True)
+                    if versions:
+                        target = versions[-1]
+        if (target is not None) and not IWorkflowPublicationInfo(target).is_visible(request):
+            target = None
+        if target is not None:
             response = Response()
             response.status_code = 302
             if view_name:  # back-office access => last version
-                version = IWorkflowVersions(results[0]).get_last_versions()[0]
-                response.location = absolute_url(version, request, '/'.join(view_name))
+                response.location = absolute_url(target, request, '/'.join(view_name))
             else:
-                version = results[0]
-                response.location = canonical_url(version, request)
+                response.location = canonical_url(target, request)
             return response
     raise NotFound()