source: products/qPloneCaptchas/tags/1.3.2/Extensions/Install.py @ 2284

Last change on this file since 2284 was 180, checked in by fenix, 18 years ago

creating branch of 0.3.2 version, migration expiriment

  • Property svn:eol-style set to native
File size: 5.4 KB
Line 
1from Products.qPloneCaptchas.config import *
2from Products.CMFCore.utils import getToolByName
3from StringIO import StringIO
4from Products.CMFCore.DirectoryView import addDirectoryViews
5import string
6from App.Common import package_home
7from os.path import exists as path_exists, join as path_join
8
9try:
10    from Products.CMFCore.permissions import ManagePortal
11except:
12    from Products.CMFCore.CMFCorePermissions import ManagePortal
13
14from random import randint
15from Products.CMFPlone.migrations.migration_util import safeEditProperty
16
17def install(self):
18    out=StringIO()
19    portal = getToolByName(self, 'portal_url').getPortalObject()
20    # add captchas_tool
21    install_tool(self, out)
22
23    safeEditProperty(self, 'captcha_key', generateKey(8))
24
25    # add Property sheet to portal_properies
26    pp = getToolByName(self, 'portal_properties')
27    if not 'qPloneCaptchas' in pp.objectIds():
28        pp.addPropertySheet(id='qPloneCaptchas', title= '%s Properties' % 'qPloneCaptchas')
29        out.write("Adding %s property sheet to portal_properies\n" % 'qPloneComments' )
30    props_sheet = pp['qPloneCaptchas']
31    updateProperties(props_sheet, out, PROPERTIES)
32
33    Layers = []
34    Layers += LAYERS
35    Layers.append(LAYER_STATIC_CAPTCHAS)
36
37    mtool = getToolByName(self, 'portal_migration')
38    plone_version = mtool.getFileSystemVersion()
39    if plone_version.startswith('2.1'):
40        plone_version = '2.1.2'
41    elif plone_version.startswith('2.0'):
42        plone_version = '2.0.5'
43    elif plone_version.startswith('2.5'):
44        plone_version = '2.5'
45    elif plone_version.startswith('3'):
46        plone_version = '3.0'
47    else:
48        raise Exception("Error - Unsupported version. Suported versions: Plone 2.0.5-3")
49
50    DiscussionLayer = LAYER_DISCUSSION
51    qi = getToolByName(self, 'portal_quickinstaller')
52    if qi.isProductInstalled('PloneFormMailer'):
53        formmailer_layer = LAYER_FORMMAILER+'/'+ plone_version
54        Layers.append(formmailer_layer)
55    discussion_layer = '/'.join([DiscussionLayer, plone_version])
56    Layers.append(discussion_layer)
57
58    join_form_layer = '/'.join([LAYER_JOIN_FORM, plone_version])
59    Layers.append(join_form_layer)
60   
61   
62    sendto_form_layer = '/'.join([LAYER_SENDTO_FORM, plone_version])
63    Layers.append(sendto_form_layer)
64
65    out.write('Call setupSkin... \n')
66    setupSkin(self, out, Layers)
67
68    # Add Configlet. Delete old version before adding, if exist one.
69    controlpanel_tool = getToolByName(self, 'portal_controlpanel')
70    controlpanel_tool.unregisterConfiglet(CONFIGLET_ID)
71    controlpanel_tool.registerConfiglet(id=CONFIGLET_ID, name=CONFIGLET_NAME, category='Products',
72                                        action='string:${portal_url}/%s' % CONFIGLET_ID,
73                                        appId=PRODUCT_NAME, permission=ManagePortal, imageUrl='group.gif')
74    return out.getvalue()
75
76def setupSkin(self, out, layers):
77    """Setup skins"""
78    skinstool=getToolByName(self, 'portal_skins')
79    addDirectoryViews(skinstool, 'skins', GLOBALS)
80
81    for skin in skinstool.getSkinSelections():
82        modified = False
83        path = skinstool.getSkinPath(skin)
84        path = map( string.strip, string.split( path,',' ) )
85        for layer in layers:
86            if not layer in path:
87                try:
88                    path.insert(path.index('custom')+1, layer )
89                except ValueError:
90                    path.append(layer)
91                modified = True
92                out.write('  Layer %s sucessfully installed into skin %s.\n' % (layer,skin))
93            else:
94                out.write('  Layer %s was already installed into skin %s.\n' % (layer,skin))
95        if modified:
96            path = string.join( path, ',' )
97            skinstool.addSkinSelection( skin, path )
98
99def uninstall(self):
100    skinstool = getToolByName(self, 'portal_skins')
101    for skinName in skinstool.getSkinSelections():
102        path = skinstool.getSkinPath(skinName)
103        path = [i.strip() for i in  path.split(',')]
104        pth  = [x for x in path
105                    if not ((x in ALL_LAYERS) or
106                            filter(lambda y:x.startswith(y), ALL_LAYERS))]
107        skinstool.addSkinSelection(skinName, ','.join(pth))
108
109     # Remove configlet
110    controlpanel_tool = getToolByName(self, 'portal_controlpanel')
111    controlpanel_tool.unregisterConfiglet(CONFIGLET_ID)
112    # Remove Product's property sheet from portal_properties
113    pp = getToolByName(self, 'portal_properties')
114    if 'qPloneCaptchas' in pp.objectIds():
115        pp.manage_delObjects(ids=['qPloneCaptchas'])
116
117def updateProperties(pp_ps, out, *args):
118    for prop in args:
119        for prop_id, prop_value, prop_type in prop:
120            if not pp_ps.hasProperty(prop_id):
121                pp_ps.manage_addProperty(prop_id, prop_value, prop_type)
122                out.write("Adding %s property to %s property sheet\n" % (prop_id, 'qPloneComments'))
123
124def generateKey(length):
125    key = ''
126    for i in range(length): key += str(randint(0, 9))
127    return key
128
129def install_tool(self, out):
130    if not hasattr(self, 'portal_captchas'):
131        addTool = self.manage_addProduct['qPloneCaptchas'].manage_addTool
132        addTool('CaptchaTool')
133
134def updateProperties(pp_ps, out, *args):
135    for prop in args:
136        for prop_id, prop_value, prop_type in prop:
137            if not pp_ps.hasProperty(prop_id):
138                pp_ps.manage_addProperty(prop_id, prop_value, prop_type)
139                out.write("Adding %s property to %s property sheet\n" % (prop_id, 'qPloneComments'))
Note: See TracBrowser for help on using the repository browser.