[2384] | 1 | import logging |
---|
[1593] | 2 | from Products.CMFCore.utils import getToolByName |
---|
[2376] | 3 | from Products.GenericSetup.upgrade import _upgrade_registry |
---|
[1593] | 4 | |
---|
[2384] | 5 | logger = logging.getLogger("quintagroup.plonegooglesitemaps") |
---|
[1593] | 6 | PROFILE = "profile-quintagroup.plonegooglesitemaps:default" |
---|
| 7 | |
---|
| 8 | def install(self, reinstall=False): |
---|
| 9 | """ Install skin with GenericSetup install profile |
---|
| 10 | """ |
---|
| 11 | ps = getToolByName(self, 'portal_setup') |
---|
| 12 | mtool = getToolByName(self, 'portal_migration') |
---|
| 13 | plone_version = mtool.getFileSystemVersion() |
---|
[2376] | 14 | isPlone3 = plone_version.startswith('3') |
---|
| 15 | isPlone4 = plone_version.startswith('4') |
---|
[1593] | 16 | |
---|
[2376] | 17 | if reinstall and (isPlone3 or isPlone4): |
---|
| 18 | step = None |
---|
| 19 | profile_id = 'quintagroup.plonegooglesitemaps:default' |
---|
[2384] | 20 | steps_to_run = [s['id'] for s in ps.listUpgrades(profile_id, show_old=False)] |
---|
[2376] | 21 | for step_id in steps_to_run: |
---|
| 22 | step = _upgrade_registry.getUpgradeStep(profile_id, step_id) |
---|
[2384] | 23 | step.doStep(ps) |
---|
[2376] | 24 | msg = "Ran upgrade step %s for profile %s" % (step.title, profile_id) |
---|
| 25 | logger.log(logging.INFO, msg) |
---|
| 26 | # We update the profile version to the last one we have reached |
---|
| 27 | # with running an upgrade step. |
---|
| 28 | if step and step.dest is not None and step.checker is None: |
---|
[2384] | 29 | ps.setLastVersionForProfile(profile_id, step.dest) |
---|
[2376] | 30 | return "Ran all reinstall steps." |
---|
| 31 | |
---|
| 32 | if (isPlone3 or isPlone4): |
---|
[1593] | 33 | # if this is plone 3.x |
---|
| 34 | (ps.aq_base).__of__(self).runAllImportStepsFromProfile(PROFILE) |
---|
| 35 | else: |
---|
| 36 | active_context_id = ps.getImportContextID() |
---|
| 37 | ps.setImportContext(PROFILE) |
---|
| 38 | ps.runAllImportSteps() |
---|
| 39 | ps.setImportContext(active_context_id) |
---|