[200] | 1 | #-*- mode: python; mode: fold -*- |
---|
[486] | 2 | # $Id: exportimport.py 1146 2006-12-29 07:00:35Z joachim $ |
---|
[199] | 3 | """WAeUP Tool XML Adapter. |
---|
| 4 | |
---|
| 5 | An XML adapter tells the GenericSetup machinery howto im- / export persistent |
---|
| 6 | configuration that is relative to a specific CMF component such as our WAeUP |
---|
| 7 | Tool. |
---|
| 8 | |
---|
| 9 | GenericSetup uses the Zope3 interfaces and components machinery to find the |
---|
| 10 | right XML adapter for the right object. This is why we flagged our waeup tool |
---|
| 11 | with the `implements(IWAeUPTool)` class attribute and made an adapter |
---|
| 12 | association in the `configure.zcml` file. |
---|
| 13 | """ |
---|
[238] | 14 | import csv,re |
---|
[199] | 15 | |
---|
| 16 | # Zope3 component architecture |
---|
[502] | 17 | from zope.app import zapi |
---|
[199] | 18 | from zope.component import adapts |
---|
| 19 | from zope.interface import implements |
---|
| 20 | |
---|
| 21 | # Standard GenericSetup base classes and functions |
---|
| 22 | from Products.GenericSetup.utils import exportObjects |
---|
| 23 | from Products.GenericSetup.utils import importObjects |
---|
| 24 | from Products.GenericSetup.utils import XMLAdapterBase |
---|
| 25 | from Products.GenericSetup.utils import PropertyManagerHelpers |
---|
| 26 | |
---|
| 27 | from Products.CMFCore.utils import getToolByName |
---|
| 28 | |
---|
| 29 | # GenericSetup multi adapts a class that implement IWAeUP and a particular |
---|
| 30 | # ISetupEnvironment to and IBody (piece of XML configuration). |
---|
| 31 | from Products.GenericSetup.interfaces import IBody |
---|
| 32 | from Products.GenericSetup.interfaces import ISetupEnviron |
---|
[274] | 33 | from Products.WAeUP_SRP.interfaces import IWAeUPTool |
---|
[238] | 34 | import Globals |
---|
| 35 | p_home = Globals.package_home(globals()) |
---|
| 36 | i_home = Globals.INSTANCE_HOME |
---|
[199] | 37 | |
---|
| 38 | TOOL = 'portal_waeup' |
---|
| 39 | NAME = 'waeup' |
---|
| 40 | |
---|
[502] | 41 | def importWAeUPTable(obj, parent_path, context, name): |
---|
| 42 | """ Import subobjects recursively. |
---|
| 43 | """ |
---|
| 44 | importer = zapi.queryMultiAdapter((obj, context), IBody) |
---|
[950] | 45 | |
---|
[502] | 46 | path = '%s%s' % (parent_path, obj.getId().replace(' ', '_')) |
---|
| 47 | __traceback_info__ = path |
---|
| 48 | if importer: |
---|
| 49 | path = '%s%s' % (parent_path, name) |
---|
| 50 | filename = '%s%s' % (path, importer.suffix) |
---|
| 51 | body = context.readDataFile(filename) |
---|
| 52 | if body is not None: |
---|
| 53 | importer.filename = filename # for error reporting |
---|
| 54 | importer.body = body |
---|
| 55 | |
---|
| 56 | if getattr(obj, 'objectValues', False): |
---|
| 57 | for sub in obj.objectValues(): |
---|
| 58 | importObjects(sub, path+'/', context) |
---|
| 59 | |
---|
[199] | 60 | def exportWAeUP(context): |
---|
| 61 | """Export our WAeUP tool configuration |
---|
| 62 | """ |
---|
| 63 | site = context.getSite() |
---|
[282] | 64 | tool = getattr(context,"campus",None) |
---|
[199] | 65 | if tool is None: |
---|
| 66 | logger = context.getLogger(NAME) |
---|
| 67 | logger.info("Nothing to export.") |
---|
| 68 | return |
---|
| 69 | exportObjects(tool, '', context) |
---|
| 70 | |
---|
| 71 | def importWAeUP(context): |
---|
| 72 | """Import WAeUP tool configuration |
---|
| 73 | """ |
---|
| 74 | site = context.getSite() |
---|
[350] | 75 | pm = site.portal_membership |
---|
[940] | 76 | campus = getattr(site.portal_url.getPortalObject(),'campus',None) |
---|
| 77 | if campus is not None: |
---|
[949] | 78 | academics = getattr(campus,'academics',None) |
---|
| 79 | students = getattr(campus,'students',None) |
---|
[963] | 80 | accommodation = getattr(campus,'accommodation',None) |
---|
[949] | 81 | if academics is not None: |
---|
[955] | 82 | academics.manage_setLocalGroupRoles(groupid='role:Authenticated', |
---|
[926] | 83 | roles=('SectionReader',)) |
---|
[949] | 84 | if students is not None: |
---|
[962] | 85 | students.manage_setLocalGroupRoles(groupid = 'ClearanceOfficers', |
---|
[955] | 86 | roles=('SectionReader',)) |
---|
[962] | 87 | students.manage_setLocalGroupRoles(groupid = 'role:Student', |
---|
| 88 | roles=('SectionReader',)) |
---|
[963] | 89 | if accommodation is not None: |
---|
| 90 | accommodation.manage_setLocalGroupRoles(groupid='role:Student', |
---|
| 91 | roles=('SectionReader',)) |
---|
[955] | 92 | members = getattr(site.portal_directories,'members') |
---|
| 93 | if members is not None: |
---|
[957] | 94 | members.manage_setLocalGroupRoles(groupid='MemberAdmins', |
---|
[955] | 95 | roles=('SectionOfficer',)) |
---|
[956] | 96 | |
---|
[926] | 97 | ## pm.setLocalGroupRoles(campus.academics,['role:Authenticated', |
---|
| 98 | ## ],'SectionReader') |
---|
[502] | 99 | importWAeUPTable(site.portal_accommodation, '', context,'accommodation') |
---|
[1146] | 100 | importWAeUPTable(site.courses_catalog, '', context,'courses_catalog') |
---|
| 101 | importWAeUPTable(site.payments_catalog, '', context,'payments_catalog') |
---|
[502] | 102 | importWAeUPTable(site.portal_pins, '', context,'pins') |
---|
[966] | 103 | importWAeUPTable(site.portal_pumeresults, '', context,'pumeresults') |
---|
[1146] | 104 | importWAeUPTable(site.registered_import, '', context,'registered_import') |
---|
| 105 | importWAeUPTable(site.results_import, '', context,'results_import') |
---|
[971] | 106 | importWAeUPTable(site.students_catalog, '', context,'students_catalog') |
---|
[950] | 107 | |
---|
[502] | 108 | from Products.CPSCore.exportimport.catalog import CatalogToolXMLAdapter |
---|
| 109 | #from Products.GenericSetup.ZCatalog.exportimport import ZCatalogXMLAdapter |
---|
[363] | 110 | |
---|
| 111 | from interfaces import IWAeUPTable |
---|
| 112 | |
---|
[502] | 113 | class WAeUPTableXMLAdapter(CatalogToolXMLAdapter): |
---|
| 114 | #class WAeUPTableXMLAdapter(ZCatalogXMLAdapter): |
---|
[363] | 115 | __used_for__ = IWAeUPTable |
---|
| 116 | _LOGGER_ID = 'waeup_table' |
---|
| 117 | |
---|
[502] | 118 | ## def _importNode(self, node): |
---|
| 119 | ## """Import the object from the DOM node. |
---|
| 120 | ## """ |
---|
| 121 | ## if self.environ.shouldPurge(): |
---|
| 122 | ## self._purgeProperties() |
---|
| 123 | ## self._purgeObjects() |
---|
| 124 | ## self._purgeIndexes() |
---|
| 125 | ## self._purgeColumns() |
---|
| 126 | ## |
---|
| 127 | ## self._logger.info('Catalog imported.') |
---|
[199] | 128 | # This the XMLAdapter itself. It encodes the im- / export logic that is specific |
---|
| 129 | # to our tool. `im- / exportObjects` functions will find it thanks to the zope |
---|
| 130 | # components machinery and the associations made in the configure.zcml file. |
---|
| 131 | |
---|
[282] | 132 | ##class WAeUPXMLAdapter(XMLAdapterBase, PropertyManagerHelpers): |
---|
| 133 | ## """XML importer and exporter for the WAeUP tool. |
---|
| 134 | ## |
---|
| 135 | ## Hence this XMLAdapter is really simple. To get more complete examples of |
---|
| 136 | ## what XMLAdapters are meant to do, please have a look at the |
---|
| 137 | ## CPSSkins.exportimport.py or CPSDirectory.exportimport.py files, for |
---|
| 138 | ## instance. |
---|
| 139 | ## """ |
---|
| 140 | ## |
---|
| 141 | ## adapts(IWAeUPTool, ISetupEnviron) |
---|
| 142 | ## implements(IBody) |
---|
| 143 | ## |
---|
| 144 | ## _LOGGER_ID = NAME |
---|
| 145 | ## name = NAME |
---|
| 146 | ## |
---|
| 147 | ## def _exportNode(self): |
---|
| 148 | ## """Export the object as a DOM node. |
---|
| 149 | ## """ |
---|
| 150 | ## node = self._getObjectNode('object') |
---|
| 151 | ## node.appendChild(self._extractProperties()) |
---|
| 152 | ## self._logger.info("WAeUP tool exported.") |
---|
| 153 | ## return node |
---|
| 154 | ## |
---|
| 155 | ## def _importNode(self, node): |
---|
| 156 | ## """Import the object from the DOM node. |
---|
| 157 | ## """ |
---|
| 158 | ## if self.environ.shouldPurge(): |
---|
| 159 | ## self._purgeProperties() |
---|
| 160 | ## self._initProperties(node) |
---|
| 161 | ## self._logger.info("WAeUP tool imported.") |
---|
| 162 | ## |
---|