/[smeserver]/cdrom.image/updates/smeupgradeclass.py
ViewVC logotype

Diff of /cdrom.image/updates/smeupgradeclass.py

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph | View Patch Patch

Revision 1.1 by slords, Sat Jul 30 07:28:39 2005 UTC Revision 1.10.2.7 by slords, Fri Aug 29 13:56:56 2008 UTC
# Line 1  Line 1 
1  from installclass import BaseInstallClass  from installclass import getBaseInstallClass
2  from rhpl.translate import N_, _  from rhpl.translate import N_, _
3  from rhpl.log import log  from constants import *
   
4  import os  import os
5  import iutil  import iutil
6    import rhpl
7    
8    baseclass = getBaseInstallClass()
9    
10    import logging
11    log = logging.getLogger("anaconda")
12    
13    import string
14    
15    class Script:
16        def __repr__(self):
17            str = ("(s: '%s' i: %s c: %d)") %  \
18                (self.script, self.interp, self.inChroot)
19            return string.replace(str, "\n", "|")
20    
21        def __init__(self, script, interp, inChroot, logfile = None):
22            self.script = script
23            self.interp = interp
24            self.inChroot = inChroot
25            self.logfile = logfile
26    
27        def run(self, chroot, serial):
28            import tempfile
29            import os.path
30    
31            if self.inChroot:
32                scriptRoot = chroot
33            else:
34                scriptRoot = "/"
35    
36            (fd, path) = tempfile.mkstemp("", "sme-script-", scriptRoot + "/tmp")
37    
38  class InstallClass(BaseInstallClass):          os.write(fd, self.script)
39            os.close(fd)
40            os.chmod(path, 0700)
41    
42            if self.logfile is not None:
43                messages = self.logfile
44            elif serial:
45                messages = "%s.log" % path
46            else:
47                messages = "/dev/tty3"
48    
49            rc = iutil.execWithRedirect(self.interp, ["/tmp/%s" % os.path.basename(path)],
50                                        stdin = messages, stdout = messages, stderr = messages,
51                                        root = scriptRoot)
52    
53            if rc != 0:
54                log.error("WARNING - Error code %s encountered running a sme script", rc)
55    
56            os.unlink(path)
57            if serial or self.logfile is not None:
58                os.chmod("%s" % messages, 0600)
59    
60    class InstallClass(baseclass):
61      name = N_("Upgrade Existing System")      name = N_("Upgrade Existing System")
62      pixmap = "upgrade.png"      pixmap = "upgrade.png"
63      sortPriority = 999999      sortPriority = 999999
# Line 16  class InstallClass(BaseInstallClass): Line 68  class InstallClass(BaseInstallClass):
68          return 't'          return 't'
69    
70      def setSteps(self, dispatch):      def setSteps(self, dispatch):
71          dispatch.setStepList(          dispatch.setStepList(
72                      "language",                      "language",
73                      "keyboard",                      "keyboard",
74                        "installtype",
75                      "findrootparts",                      "findrootparts",
76                        "findinstall",
77                      "partitionobjinit",                      "partitionobjinit",
78                      "upgrademount",                      "upgrademount",
79                      "upgrademigfind",                      "upgrademigfind",
80                      "upgrademigratefs",                      "upgrademigratefs",
81                      "upgradecontinue",                      "upgradecontinue",
82                      "readcomps",                      "reposetup",
83                      "findpackages",                      "upgbootloader",
84                      "checkdeps",                      "checkdeps",
85                      "dependencies",                      "dependencies",
86                      "install",                      "postselection",
87                        "confirminstall",
88                        "install",
89                      "migratefilesystems",                      "migratefilesystems",
90                      "preinstallconfig",                      "preinstallconfig",
91                      "installpackages",                      "installpackages",
# Line 38  class InstallClass(BaseInstallClass): Line 94  class InstallClass(BaseInstallClass):
94                      "dopostaction",                      "dopostaction",
95                      "methodcomplete",                      "methodcomplete",
96                      "copylogs",                      "copylogs",
97                      "complete"                      "complete"
98                  )                  )
99    
100      def postAction(self, rootPath, serial):          if iutil.getPPCMachine() == "iSeries":
101          if serial:              dispatch.skipStep("bootloadersetup", skip = 0)
             messages = "/tmp/postupgrade.log"  
         else:  
             messages = "/dev/tty3"  
         args = [ "/usr/sbin/lokkit", "--quiet", "--nostart", "--selinux=disabled"]  
   
         try:  
             iutil.execWithRedirect(args[0], args, root=rootPath,  
                                    stdout=messages, stderr=messages)  
         except RuntimeError, msg:  
             log ("lokkit run failed: %s", msg)  
         except OSError, (errno, msg):  
             log ("lokkit run failed: %s", msg)  
   
         path = rootPath + "/tmp/postupgrade.sh"  
         cmds = ["/sbin/syslogd &", "sleep 2", "/sbin/e-smith/signal-event post-upgrade"]  
   
         f = open(path, "w")  
         f.writelines(cmds)  
         f.close  
         os.chmod(path, 0700)  
102    
103          rc = iutil.execWithRedirect("/bin/sh", ["/bin/sh", "/tmp/postupgrade.sh"],          if rhpl.getArch() != "i386" and rhpl.getArch() != "x86_64":
104                         stdout=messages, stderr=messages, root=rootPath)              dispatch.skipStep("bootloader")
105          if rc != 0:              dispatch.skipStep("bootloaderadvanced")
106              log("WARNING - Error code %s encountered running postupgrade script", rc)  
107          os.unlink(path)          if rhpl.getArch() != "i386" and rhpl.getArch() != "x86_64":
108                dispatch.skipStep("upgbootloader")            
109      def setInstallData(self, id):  
110          BaseInstallClass.setInstallData(self, id)      def postAction(self, anaconda, serial):
111          id.upgrade.set(1)          win = anaconda.intf.waitWindow(_("Post Upgrade Script"),
112               _("The post upgrade script is running..."))
113    
114            script = ( "#!/bin/sh\nmkdir -p /var/lib/dhcp; /sbin/syslogd ; sleep 2; /sbin/e-smith/signal-event post-upgrade\n" )
115            s = Script(script, interp="/bin/sh", inChroot=1)
116            log.info("%s", s)
117            s.run(anaconda.rootPath, serial)
118            win.pop()
119    
120        def setInstallData(self, anaconda):
121            baseclass.setInstallData(self, anaconda)
122            anaconda.id.setUpgrade(True)
123            
124      def __init__(self, expert):      def __init__(self, expert):
125          BaseInstallClass.__init__(self, expert)          baseclass.__init__(self, expert)


Legend:
Removed lines/characters  
Changed lines/characters
  Added lines/characters

admin@koozali.org
ViewVC Help
Powered by ViewVC 1.2.1 RSS 2.0 feed