Commit b28f03f7 authored by wenjie.zheng's avatar wenjie.zheng

Workflow.py: add function getPortalTypeListForWorkflow.

parent bbcd0d0c
...@@ -426,7 +426,7 @@ class Workflow(IdAsReferenceMixin("", "prefix"), XMLObject): ...@@ -426,7 +426,7 @@ class Workflow(IdAsReferenceMixin("", "prefix"), XMLObject):
''' '''
if name == self.getStateVariable(): if name == self.getStateVariable():
return self._getWorkflowStateOf(ob, 1) return self._getWorkflowStateOf(ob, 1)
vdef = self.getVariableValueList().get(name) vdef = self.getVariableValueList()[name]
if vdef.getInfoGuard() is not None and not vdef.getInfoGuard().check( if vdef.getInfoGuard() is not None and not vdef.getInfoGuard().check(
getSecurityManager(), self, ob): getSecurityManager(), self, ob):
return default return default
...@@ -980,6 +980,18 @@ class Workflow(IdAsReferenceMixin("", "prefix"), XMLObject): ...@@ -980,6 +980,18 @@ class Workflow(IdAsReferenceMixin("", "prefix"), XMLObject):
return etree.tostring(root, encoding='utf-8', return etree.tostring(root, encoding='utf-8',
xml_declaration=True, pretty_print=True) xml_declaration=True, pretty_print=True)
# Get list of portal types for workflow
def getPortalTypeListForWorkflow(self):
"""
Get list of portal types for workflow.
"""
result = []
workflow_id = self.getId()
for portal_type in self.getPortalObject().portal_types.objectValues():
if workflow_id in portal_type.getTypeWorkflowList():
result.append(portal_type.getId())
return result
def _executeMetaTransition(self, ob, new_state_id): def _executeMetaTransition(self, ob, new_state_id):
""" """
Allow jumping from state to another without triggering any hooks. Allow jumping from state to another without triggering any hooks.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment