source: publico/ILSAALMaterial/trunk/Extensions/Install.py @ 1540

Última Alteração nesse arquivo desde 1540 foi 1540, incluída por joaoantonio, 14 anos atrás

novo codigo gerado

File size: 7.0 KB
Linha 
1""" Extensions/Install.py """
2
3# Copyright (c) 2005 by Interlegis
4#
5# Generated:
6# Generator: ArchGenXML Version 1.4.0-RC1 devel
7#            http://plone.org/products/archgenxml
8#
9# GNU General Public Licence (GPL)
10#
11# This program is free software; you can redistribute it and/or modify it under
12# the terms of the GNU General Public License as published by the Free Software
13# Foundation; either version 2 of the License, or (at your option) any later
14# version.
15# This program is distributed in the hope that it will be useful, but WITHOUT
16# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
17# FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
18# details.
19# You should have received a copy of the GNU General Public License along with
20# this program; if not, write to the Free Software Foundation, Inc., 59 Temple
21# Place, Suite 330, Boston, MA  02111-1307  USA
22#
23__author__    = '''STC Interlegis <stc@interlegis.gov.br>'''
24__docformat__ = 'plaintext'
25__version__   = '$ Revision 0.0 $'[11:-2]
26
27import os.path
28import sys
29from StringIO import StringIO
30
31from App.Common import package_home
32from Products.CMFCore.utils import getToolByName
33from Products.CMFCore.utils import manage_addTool
34from Products.ExternalMethod.ExternalMethod import ExternalMethod
35from zExceptions import NotFound, BadRequest
36
37from Products.Archetypes.Extensions.utils import installTypes
38from Products.Archetypes.Extensions.utils import install_subskin
39try:
40    from Products.Archetypes.lib.register import listTypes
41except ImportError:
42    from Products.Archetypes.public import listTypes
43from Products.ILSAALMaterial.config import PROJECTNAME
44from Products.ILSAALMaterial.config import product_globals as GLOBALS
45
46def install(self):
47    """ External Method to install ILSAALMaterial """
48    out = StringIO()
49    print >> out, "Installation log of %s:" % PROJECTNAME
50
51    # If the config contains a list of dependencies, try to install
52    # them.  Add a list called DEPENDENCIES to your custom
53    # AppConfig.py (imported by config.py) to use it.
54    try:
55        from Products.ILSAALMaterial.config import DEPENDENCIES
56    except:
57        DEPENDENCIES = []
58    portal = getToolByName(self,'portal_url').getPortalObject()
59    quickinstaller = portal.portal_quickinstaller
60    for dependency in DEPENDENCIES:
61        print >> out, "Installing dependency %s:" % dependency
62        quickinstaller.installProduct(dependency)
63        get_transaction().commit(1)
64
65    classes = listTypes(PROJECTNAME)
66    installTypes(self, out,
67                 classes,
68                 PROJECTNAME)
69    install_subskin(self, out, GLOBALS)
70
71               
72    # Create vocabularies in vocabulary lib
73    atvm = getToolByName(self, 'portal_vocabularies')
74    vocabmap = {u'local_requisicao': ('SimpleVocabulary', 'SimpleVocabularyTerm'),
75         u'local_almoxarifado': ('SimpleVocabulary', 'SimpleVocabularyTerm'),
76         u'unidade_medida': ('SimpleVocabulary', 'SimpleVocabularyTerm'),
77        }
78    for vocabname in vocabmap.keys():
79        if not vocabname in atvm.contentIds():
80            atvm.invokeFactory(vocabmap[vocabname][0], vocabname)
81        if vocabmap[vocabname][0] != "VdexVocabulary" and \
82           len(atvm[vocabname].contentIds()) < 1:
83            atvm[vocabname].invokeFactory(vocabmap[vocabname][1],'default')
84            atvm[vocabname]['default'].setTitle('Default term, replace it by your own stuff')
85
86    # try to call a workflow install method
87    # in 'InstallWorkflows.py' method 'installWorkflows'
88    try:
89        installWorkflows = ExternalMethod('temp','temp',PROJECTNAME+'.InstallWorkflows', 'installWorkflows').__of__(self)
90    except NotFound:
91        installWorkflows = None
92
93    if installWorkflows:
94        print >>out,'Workflow Install:'
95        res = installWorkflows(self,out)
96        print >>out,res or 'no output'
97    else:
98        print >>out,'no workflow install'
99
100    #bind classes to workflows
101    wft = getToolByName(self,'portal_workflow')
102
103    # enable portal_factory for given types
104    factory_tool = getToolByName(self,'portal_factory')
105    factory_types=[
106        ] + factory_tool.getFactoryTypes().keys()
107    factory_tool.manage_setPortalFactoryTypes(listOfTypeIds=factory_types)
108
109    # For plone 2.1, allow the easy registering of stylesheets
110    from Products.ILSAALMaterial.config import HAS_PLONE21
111    if HAS_PLONE21:
112        try:
113            from Products.ILSAALMaterial.config import STYLESHEETS
114        except:
115            STYLESHEETS = []
116        try:
117            from Products.ILSAALMaterial.config import JAVASCRIPTS
118        except:
119            JAVASCRIPTS = []
120        portal_css = getToolByName(portal, 'portal_css')
121        portal_javascripts = getToolByName(portal, 'portal_javascripts')
122        for stylesheet in STYLESHEETS:
123            try:
124                portal_css.unregisterResource(stylesheet['id'])
125            except:
126                pass
127            defaulttitle = '%s %s' % (PROJECTNAME, stylesheet['id'])
128            defaults = {'id': '',
129            'expression': None,
130            'media': 'all',
131            'title': defaulttitle,
132            'enabled': True}
133            defaults.update(stylesheet)
134            portal_css.manage_addStylesheet(**defaults)
135        for javascript in JAVASCRIPTS:
136            try:
137                portal_javascripts.unregisterResource(stylesheet['id'])
138            except:
139                pass
140            defaults = {'id': '',
141            'expression': '',
142            'inline': False,
143            'enabled': True,
144            'cookable': True}
145            defaults.update(javascript)
146            portal_javascripts.registerScript(**defaults)
147
148    # try to call a custom install method
149    # in 'AppInstall.py' method 'install'
150    try:
151        install = ExternalMethod('temp','temp',PROJECTNAME+'.AppInstall', 'install')
152    except NotFound:
153        install = None
154
155    if install:
156        print >>out,'Custom Install:'
157        res = install(self)
158        if res:
159            print >>out,res
160        else:
161            print >>out,'no output'
162    else:
163        print >>out,'no custom install'
164    return out.getvalue()
165
166def uninstall(self):
167    out = StringIO()
168
169    # try to call a workflow uninstall method
170    # in 'InstallWorkflows.py' method 'uninstallWorkflows'
171    try:
172        installWorkflows = ExternalMethod('temp','temp',PROJECTNAME+'.InstallWorkflows', 'uninstallWorkflows').__of__(self)
173    except NotFound:
174        installWorkflows = None
175
176    if installWorkflows:
177        print >>out,'Workflow Uninstall:'
178        res = uninstallWorkflows(self,out)
179        print >>out,res or 'no output'
180    else:
181        print >>out,'no workflow uninstall'
182
183    # try to call a custom uninstall method
184    # in 'AppInstall.py' method 'uninstall'
185    try:
186        uninstall = ExternalMethod('temp','temp',PROJECTNAME+'.AppInstall', 'uninstall')
187    except:
188        uninstall = None
189
190    if uninstall:
191        print >>out,'Custom Uninstall:'
192        res = uninstall(self)
193        if res:
194            print >>out,res
195        else:
196            print >>out,'no output'
197    else:
198        print >>out,'no custom uninstall'
199
200    return out.getvalue()
Note: Veja TracBrowser para ajuda no uso do navegador do trac.
 

The contents and data of this website are published under license:
Creative Commons 4.0 Brasil - Atribuir Fonte - Compartilhar Igual.