diff --git a/product/ERP5/Document/BusinessTemplate.py b/product/ERP5/Document/BusinessTemplate.py index be2df23771aabaa7e199144775954b64fc67d8f1..545a37ba62aedb3cbd798b51f3195b80c5f7181c 100755 --- a/product/ERP5/Document/BusinessTemplate.py +++ b/product/ERP5/Document/BusinessTemplate.py @@ -78,6 +78,36 @@ class ObjectTemplateItem(Implicit): else: container._importObjectFromFile(cStringIO.StringIO(self.export_string)) +class PortalTypeTemplateItem(Implicit): + """ + Attributes: + + tool_id -- Id of the tool + relative_url_or_id -- URL relative to the tool + relative_url -- Complete relative_url + """ + export_string = None + + def __init__(self, ob, **kw): + self.__dict__.update(kw) + self.export_string = cStringIO.StringIO() + ob._p_jar.exportFile(ob._p_oid, self.export_string) + self.export_string.seek(0) + self.export_string = self.export_string.read() + + def install(self, local_configuration): + portal = local_configuration.getPortalObject() + container_path = self.relative_url.split('/')[0:-1] + object_id = self.relative_url.split('/')[-1] + container = portal.unrestrictedTraverse(container_path) + #LOG('Installing' , 0, '%s in %s with %s' % (self.id, container.getPhysicalPath(), self.export_string)) + container_ids = container.objectIds() + if object_id in container_ids: # Object already exists + pass # Do nothing for now + else: + container._importObjectFromFile(cStringIO.StringIO(self.export_string)) + + class CatalogMethodTemplateItem(ObjectTemplateItem): def __init__(self, ob, **kw): @@ -299,6 +329,7 @@ Une ligne tarifaire.""" def initInstance(self): self._object_archive = PersistentMapping() + self._portal_type_archive = PersistentMapping() self._action_archive = PersistentMapping() self._property_archive = PersistentMapping() self._module_archive = PersistentMapping() @@ -335,6 +366,26 @@ Une ligne tarifaire.""" relative_url=relative_url, relative_url_or_id=relative_url_or_id) + def addPortalTypeTemplateItem(self, relative_url_or_id, tool_id=None): + if relative_url_or_id in ('', None): return # Make sure empty lines are eliminated + p = self.getPortalObject() + if tool_id is not None: + relative_url = "%s/%s" % (tool_id, relative_url_or_id) + object = p.unrestrictedTraverse(relative_url) + if object is not None: + # Set the workflow_chain thanks to the portal_workflow + portal_type = relative_url_or_id + (default_chain, chain_dict) = self._getChainByType() + workflow_chain = chain_dict['chain_%s' % portal_type] + self._portal_type_archive[(relative_url_or_id, tool_id)] = \ + PortalTypeTemplateItem(object, + id = object.id, + tool_id=tool_id, + relative_url=relative_url, + relative_url_or_id=relative_url_or_id, + portal_type = portal_type, + workflow_chain = workflow_chain) + def addCatalogMethodTemplateItem(self, relative_url_or_id, tool_id=None): if relative_url_or_id in ('', None): return # Make sure empty lines are eliminated p = self.getPortalObject() @@ -414,7 +465,7 @@ Une ligne tarifaire.""" # Copy portal_types for id in self.getTemplatePortalTypeIdList(): - self.addObjectTemplateItem(id, 'portal_types') + self.addPortalTypeTemplateItem(id, 'portal_types') # Copy workflows for id in self.getTemplateWorkflowIdList(): self.addObjectTemplateItem(id, 'portal_workflow') @@ -500,6 +551,7 @@ Une ligne tarifaire.""" # This may include mappings self.portal_templates.updateLocalConfiguration(self, **kw) local_configuration = self.portal_templates.getLocalConfiguration(self) + LOG('install Business Template: ',0,'local dictionnary updated') # Classes and security information self.installPropertySheets(local_configuration, update=update) @@ -507,18 +559,26 @@ Une ligne tarifaire.""" self.installExtensions(local_configuration, update=update) self.installRoles(local_configuration, update=update) self.installPermissions(local_configuration, update=update) + LOG('install Business Template: ',0,'security information updated') # Objects and properties self.installObjects(local_configuration, update=update) self.installProperties(local_configuration, update=update) + LOG('install Business Template: ',0,'object and properties updated') # Skins self.installSkins(local_configuration, update=update) + LOG('install Business Template: ',0,'skins updated') + + # Portal Types + self.installPortalTypes(local_configuration, update=update) + LOG('install Business Template: ',0,'portal types updated') # Actions, modules, catalog self.installActions(local_configuration, update=update) self.installModules(local_configuration, update=update) self.installCatalog(local_configuration, update=update) + LOG('install Business Template: ',0,'action, modules and catalog updated') def installPropertySheets(self, local_configuration, update=0): @@ -614,3 +674,55 @@ Une ligne tarifaire.""" """ for o in self._object_archive.values(): o.install(local_configuration) + + def installPortalTypes(self, local_configuration, update=0): + """ + """ + portal_workflow = self.portal_workflow + for o in self._portal_type_archive.values(): + o.install(local_configuration) + # We now need to setup the list of workflows corresponding to + # each portal type + (default_chain, chain_dict) = self._getChainByType() + # Set the default chain to the empty string is probably the + # best solution, by default it is 'default_workflow', wich is + # not very usefull + default_chain = '' + LOG('installPortalTypes, portal_type: ',0,o.portal_type) + LOG('installPortalTypes, workflow_chain: ',0,repr(o.workflow_chain)) + LOG('installPortalTypes, chain_dict: ',0,chain_dict) + LOG('installPortalTypes, default_chain: ',0,default_chain) + chain_dict['chain_%s' % o.portal_type] = o.workflow_chain + portal_workflow.manage_changeWorkflows(default_chain,props=chain_dict) + + def _getChainByType(self): + """ + This is used in order to construct the full list + of mapping between type and list of workflow associated + This is only usefull in order to use + portal_workflow.manage_changeWorkflows + """ + self = self.portal_workflow + cbt = self._chains_by_type + ti = self._listTypeInfo() + types_info = [] + for t in ti: + id = t.getId() + title = t.Title() + if title == id: + title = None + if cbt is not None and cbt.has_key(id): + chain = ', '.join(cbt[id]) + else: + chain = '(Default)' + types_info.append({'id': id, + 'title': title, + 'chain': chain}) + new_dict = {} + for item in types_info: + new_dict['chain_%s' % item['id']] = item['chain'] + default_chain=', '.join(self._default_chain) + return (default_chain, new_dict) + + +