source: publico/ILIntranet/trunk/Extensions/Install.py @ 486

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

Criados os índices e metadados do catálogo para a view da pasta

File size: 4.7 KB
Linha 
1""" Extensions/Install.py """
2
3# Copyright (c) 2005 by Interlegis
4#
5# Generated:
6# Generator: ArchGenXML Version 1.4.0-beta1 devel
7#            http://sf.net/projects/archetypes/
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 <admin-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.ILIntranet.config import PROJECTNAME
44from Products.ILIntranet.config import product_globals as GLOBALS
45
46def install(self):
47    """ External Method to install ILIntranet """
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.ILIntranet.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    # try to call a workflow install method
73    # in 'InstallWorkflows.py' method 'installWorkflows'
74    try:
75        installWorkflows = ExternalMethod('temp','temp',PROJECTNAME+'.InstallWorkflows', 'installWorkflows').__of__(self)
76    except NotFound:
77        installWorkflows = None
78
79    if installWorkflows:
80        print >>out,'Workflow Install:'
81        res = installWorkflows(self,out)
82        print >>out,res or 'no output'
83    else:
84        print >>out,'no workflow install'
85
86    #bind classes to workflows
87    wft = getToolByName(self,'portal_workflow')
88    wft.setChainForPortalTypes( ['PastaLigacaoInterurbana'], "folder_workflow")
89
90
91    # try to call a custom install method
92    # in 'AppInstall.py' method 'install'
93    try:
94        install = ExternalMethod('temp','temp',PROJECTNAME+'.AppInstall', 'install')
95    except NotFound:
96        install = None
97
98    if install:
99        print >>out,'Custom Install:'
100        res = install(self)
101        if res:
102            print >>out,res
103        else:
104            print >>out,'no output'
105    else:
106        print >>out,'no custom install'
107    return out.getvalue()
108
109def uninstall(self):
110    out = StringIO()
111
112    # try to call a workflow uninstall method
113    # in 'InstallWorkflows.py' method 'uninstallWorkflows'
114    try:
115        installWorkflows = ExternalMethod('temp','temp',PROJECTNAME+'.InstallWorkflows', 'uninstallWorkflows').__of__(self)
116    except NotFound:
117        installWorkflows = None
118
119    if installWorkflows:
120        print >>out,'Workflow Uninstall:'
121        res = uninstallWorkflows(self,out)
122        print >>out,res or 'no output'
123    else:
124        print >>out,'no workflow uninstall'
125
126    # try to call a custom uninstall method
127    # in 'AppInstall.py' method 'uninstall'
128    try:
129        uninstall = ExternalMethod('temp','temp',PROJECTNAME+'.AppInstall', 'uninstall')
130    except:
131        uninstall = None
132
133    if uninstall:
134        print >>out,'Custom Uninstall:'
135        res = uninstall(self)
136        if res:
137            print >>out,res
138        else:
139            print >>out,'no output'
140    else:
141        print >>out,'no custom uninstall'
142
143    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.