/[smeserver]/cdrom.image/sme8/updates/installclasses/smeinstallclass.py
ViewVC logotype

Contents of /cdrom.image/sme8/updates/installclasses/smeinstallclass.py

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


Revision 1.9 - (show annotations) (download) (as text)
Sat Jun 11 23:00:46 2011 UTC (13 years, 7 months ago) by slords
Branch: MAIN
Changes since 1.8: +11 -7 lines
Content type: text/x-python
Make ext4 configurable

1 from installclass import BaseInstallClass
2 from rhpl.translate import N_, _
3 from constants import *
4 import os
5 import iutil
6 from fsset import *
7 from flags import flags
8
9 from autopart import getAutopartitionBoot, autoCreatePartitionRequests, autoCreateLVMPartitionRequests
10
11 import logging
12 log = logging.getLogger("anaconda")
13
14 import string
15 import partRequests
16 import partedUtils
17
18 class Script:
19 def __repr__(self):
20 str = ("(s: '%s' i: %s c: %d)") % \
21 (self.script, self.interp, self.inChroot)
22 return string.replace(str, "\n", "|")
23
24 def __init__(self, script, interp, inChroot, logfile = None):
25 self.script = script
26 self.interp = interp
27 self.inChroot = inChroot
28 self.logfile = logfile
29
30 def run(self, chroot, serial):
31 import tempfile
32 import os.path
33
34 if self.inChroot:
35 scriptRoot = chroot
36 else:
37 scriptRoot = "/"
38
39 (fd, path) = tempfile.mkstemp("", "sme-script-", scriptRoot + "/tmp")
40
41 os.write(fd, self.script)
42 os.close(fd)
43 os.chmod(path, 0700)
44
45 if self.logfile is not None:
46 messages = self.logfile
47 elif serial:
48 messages = "%s.log" % path
49 else:
50 messages = "/dev/tty3"
51
52 rc = iutil.execWithRedirect(self.interp, ["/tmp/%s" % os.path.basename(path)],
53 stdin = messages, stdout = messages, stderr = messages,
54 root = scriptRoot)
55
56 if rc != 0:
57 log.error("WARNING - Error code %s encountered running a sme script", rc)
58
59 os.unlink(path)
60 if serial or self.logfile is not None:
61 os.chmod("%s" % messages, 0600)
62
63 class InstallClass(BaseInstallClass):
64 id = "smeserver"
65 name = N_("New _SME Server Install")
66 pixmap = "smeserver.png"
67 description = N_("This option performs a new install of "
68 "SME Server. All attached hard drives "
69 "will be repartitioned and formated.")
70
71 sortPriority = 1
72
73 parentClass = ( _("Install SME Server"), "smeserver.png" )
74
75 def requiredDisplayMode(self):
76 return 't'
77
78 def setSteps(self, dispatch):
79 dispatch.setStepList(
80 "betanag",
81 "language",
82 "keyboard",
83 "findrootparts",
84 "partitionobjinit",
85 "autopartitionexecute",
86 "partitiondone",
87 "bootloadersetup",
88 "timezone",
89 "reposetup",
90 "basepkgsel",
91 "postselection",
92 "confirminstall",
93 "install",
94 "enablefilesystems",
95 "migratefilesystems",
96 "setuptime",
97 "preinstallconfig",
98 "installpackages",
99 "postinstallconfig",
100 "writeconfig",
101 "instbootloader",
102 "writeksconfig",
103 "setfilecon",
104 "copylogs",
105 "methodcomplete",
106 "dopostaction",
107 "complete"
108 )
109
110 dispatch.skipStep("bootloader", permanent = 1)
111 # 'partition' can be used on the command line to force
112 # verification of partitions. useful in some cases...
113 dispatch.skipStep("partition", skip = (1,0)[flags.cmdline.has_key("partition")])
114
115 def setDefaultPartitioning(self, partitions, clear = CLEARPART_TYPE_LINUX, doClear = 1):
116 diskset = self.anaconda.id.diskset
117
118 if flags.cmdline.has_key("exclude"):
119 alldrives = filter(lambda x:not (partedUtils.hasProtectedPartitions(x, self.anaconda) or
120 x in flags.cmdline["exclude"].split(",")), diskset.disks.keys())
121 else:
122 alldrives = filter(lambda x:not partedUtils.hasProtectedPartitions(x, self.anaconda), diskset.disks.keys())
123
124 if flags.cmdline.has_key("drives"):
125 if flags.cmdline["drives"] == "all":
126 drives = alldrives
127 else:
128 drives = filter(lambda x:x in flags.cmdline["drives"].split(","), alldrives)
129 else:
130 drives = filter(lambda x:not isys.driveUsesModule(x, ["usb-storage", "ub", "sbp2"]), alldrives)
131
132 if flags.cmdline.has_key("spares"):
133 if flags.cmdline["spares"] == "none":
134 spares = 0
135 else:
136 try:
137 spares = max(0,min(int(flags.cmdline["spares"]),len(drives)-2))
138 except:
139 spares = (len(drives)+4)/7
140 else:
141 spares = (len(drives)+4)/7
142
143 if flags.cmdline.has_key("raid") and flags.cmdline["raid"] in ["none","0","1","5","6"]:
144 if flags.cmdline["raid"] == "none":
145 level = 0
146 else:
147 level = int(flags.cmdline["raid"])
148 if level == 0:
149 del drives[1:]
150 spares = 0
151 if level == 6 and len(drives)-spares < 4:
152 level = 5
153 if level == 5 and len(drives)-spares < 3:
154 level = 1
155 if level == 1:
156 if spares > 1 and not flags.cmdline.has_key("spares"):
157 spares = 1
158 del drives[2+spares:]
159 elif len(drives) > 1 and len(drives) == len(filter(lambda x:x.startswith('mapper/'), alldrives)):
160 level = -1
161 del drives[1:]
162 spares = 0
163 else:
164 if len(drives) - spares >= 6:
165 level = 6
166 elif len(drives) - spares >= 3:
167 level = 5
168 else:
169 level = 1
170
171 if len(drives) >= 1:
172 log.info("Using the following drives: %s" % drives)
173 excluded = filter(lambda x:x not in drives, diskset.disks.keys())
174 if excluded:
175 log.info("Excluding the following drives: %s" % excluded)
176 skipped = filter(lambda x:x not in diskset.disks.keys(), diskset.driveList())
177 if skipped:
178 log.info("Skipping the following drives: %s" % skipped)
179 if level >= 1:
180 log.info("Installing using RAID%s" % level)
181 log.info("Using %s spare drives" % spares)
182 elif level < 0:
183 log.warning("Detected BIOS raid (skipping raid)")
184 else:
185 log.warning("Installing without using RAID")
186
187 fstype = "ext3"
188 if flags.cmdline.has_key("ext4"):
189 fstype = "ext4"
190
191 (swapMin, swapMax) = iutil.swapSuggestion()
192 if level >= 1:
193 raid1 = []
194 raid2 = []
195 raid3 = []
196 uniqueID = 100
197
198 for drive in drives:
199 request = partRequests.PartitionSpec(fileSystemTypeGet("software RAID"),
200 drive=[drive], size=100, primary=1, format=1)
201 request.uniqueID = uniqueID
202 raid1.append(uniqueID)
203 partitions.autoPartitionRequests.append(request)
204
205 if not flags.cmdline.has_key("nolvm"):
206 if not flags.cmdline.has_key("multipart"):
207 request = partRequests.PartitionSpec(fileSystemTypeGet("software RAID"),
208 size=(swapMin+1536)/(len(drives)-spares-max(0,level-4)),
209 drive=[drive], primary=1, grow=1, format=1)
210 else:
211 request = partRequests.PartitionSpec(fileSystemTypeGet("software RAID"),
212 size=(swapMin+5120)/(len(drives)-spares-max(0,level-4)),
213 drive=[drive], primary=1, grow=1, format=1)
214 request.uniqueID = uniqueID + 50
215 raid2.append(uniqueID + 50)
216 partitions.autoPartitionRequests.append(request)
217 else:
218 request = partRequests.PartitionSpec(fileSystemTypeGet("software RAID"),
219 drive=[drive], size=swapMin/(len(drives)-spares-max(0,level-4))+10, grow=1,
220 maxSizeMB=swapMax/(len(drives)-spares-max(0,level-4)), format=1, primary=1)
221 request.uniqueID = uniqueID + 30
222 raid2.append(uniqueID + 30)
223 partitions.autoPartitionRequests.append(request)
224
225 request = partRequests.PartitionSpec(fileSystemTypeGet("software RAID"),
226 size=1536/(len(drives)-spares-max(0,level-4)),
227 drive=[drive], grow=1, primary=1, format=1)
228 request.uniqueID = uniqueID + 60
229 raid3.append(uniqueID + 60)
230 partitions.autoPartitionRequests.append(request)
231
232 uniqueID = uniqueID + 1
233
234 partitions.autoPartitionRequests.append(partRequests.RaidRequestSpec(fileSystemTypeGet("ext3"),
235 mountpoint="/boot", raidmembers=raid1, raidlevel="RAID1", raidminor=1, format=1,
236 raidspares=0))
237
238 if not flags.cmdline.has_key("nolvm"):
239 request = partRequests.RaidRequestSpec(fileSystemTypeGet("physical volume (LVM)"),
240 raidmembers=raid2, raidlevel="RAID"+str(level), raidminor=2, format=1,
241 raidspares=spares)
242 request.uniqueID = 200
243 partitions.autoPartitionRequests.append(request)
244 else:
245 partitions.autoPartitionRequests.append(partRequests.RaidRequestSpec(fileSystemTypeGet("swap"),
246 raidmembers=raid2, raidlevel="RAID"+str(level), raidminor=2, format=1, raidspares=spares))
247
248 partitions.autoPartitionRequests.append(partRequests.RaidRequestSpec(fileSystemTypeGet(fstype),
249 mountpoint="/", raidmembers=raid3, raidlevel="RAID"+str(level), raidminor=3, format=1,
250 raidspares=spares))
251
252 else:
253 for drive in drives:
254 partitions.autoPartitionRequests.append(partRequests.PartitionSpec(fileSystemTypeGet("ext3"),
255 mountpoint="/boot", drive=[drive], size=100, primary=1, format=1))
256
257 if not flags.cmdline.has_key("nolvm"):
258 if not flags.cmdline.has_key("multipart"):
259 request = partRequests.PartitionSpec(fileSystemTypeGet("physical volume (LVM)"),
260 drive=[drive], size=swapMin+1536, grow=1, primary=1, format=1)
261 else:
262 request = partRequests.PartitionSpec(fileSystemTypeGet("physical volume (LVM)"),
263 drive=[drive], size=swapMin+5120, grow=1, primary=1, format=1)
264 request.uniqueID = 200
265 partitions.autoPartitionRequests.append(request)
266 else:
267 partitions.autoPartitionRequests.append(partRequests.PartitionSpec(fileSystemTypeGet(fstype),
268 mountpoint="/", drive=[drive], size=1536, grow=1, primary=1, format=1))
269
270 partitions.autoPartitionRequests.append(partRequests.PartitionSpec(fileSystemTypeGet("swap"),
271 drive=[drive], size=swapMin, maxSizeMB=swapMax, grow=1, primary=1, format=1))
272
273 if not flags.cmdline.has_key("nolvm"):
274 request = partRequests.VolumeGroupRequestSpec(vgname="main", physvols=[200], pesize=32768, format=1)
275 request.uniqueID = 201
276 partitions.autoPartitionRequests.append(request)
277
278 if not flags.cmdline.has_key("multipart"):
279 partitions.autoPartitionRequests.append(partRequests.LogicalVolumeRequestSpec(fileSystemTypeGet(fstype),
280 mountpoint="/", size=1536, volgroup=201, lvname="root", grow=1, format=1))
281
282 partitions.autoPartitionRequests.append(partRequests.LogicalVolumeRequestSpec(fileSystemTypeGet("swap"),
283 size=swapMin, maxSizeMB=swapMax, volgroup=201, lvname="swap", grow=1, format=1))
284 else:
285 partitions.autoPartitionRequests.append(partRequests.LogicalVolumeRequestSpec(fileSystemTypeGet(fstype),
286 mountpoint="/", size=2048, maxSizeMB=4096, volgroup=201, lvname="root", grow=1, format=1))
287
288 partitions.autoPartitionRequests.append(partRequests.LogicalVolumeRequestSpec(fileSystemTypeGet(fstype),
289 mountpoint="/var", size=1024, maxSizeMB=4096, volgroup=201, lvname="var", grow=1, format=1))
290
291 partitions.autoPartitionRequests.append(partRequests.LogicalVolumeRequestSpec(fileSystemTypeGet(fstype),
292 mountpoint="/home/e-smith/files", size=1024, maxSizeMB=8192, volgroup=201, lvname="files", grow=1, format=1))
293
294 partitions.autoPartitionRequests.append(partRequests.LogicalVolumeRequestSpec(fileSystemTypeGet(fstype),
295 mountpoint="/tmp", size=1024, maxSizeMB=4096, volgroup=201, lvname="tmp", grow=1, format=1))
296
297 partitions.autoPartitionRequests.append(partRequests.LogicalVolumeRequestSpec(fileSystemTypeGet("swap"),
298 size=swapMin, maxSizeMB=swapMax, volgroup=201, lvname="swap", grow=1, format=1))
299
300 partitions.autoClearPartType = CLEARPART_TYPE_ALL
301 partitions.autoClearPartDrives = drives
302 else:
303 log.warning("Not useable drives found. Enabling manual partitioning.")
304 BaseInstallClass.setDefaultPartitioning(self, partitions, clear = CLEARPART_TYPE_ALL, doClear = True)
305 self.anaconda.dispatch.skipStep("parttype", skip = 0)
306 self.anaconda.dispatch.skipStep("partition", skip = 0)
307
308 def setAsHeadless(self, dispatch, isHeadless = 0):
309 if isHeadless == 0:
310 pass
311 else:
312 dispatch.skipStep("handleX11pkgs", permanent = 1)
313 dispatch.skipStep("videocard", permanent = 1)
314 dispatch.skipStep("monitor", permanent = 1)
315 dispatch.skipStep("xcustom", permanent = 1)
316 dispatch.skipStep("writexconfig", permanent = 1)
317
318 def postAction(self, anaconda, serial):
319 win = anaconda.intf.waitWindow(_("Post Install Script"),
320 _("The post installation script is running..."))
321
322 script = ( "#!/bin/sh\nmkdir -p /var/lib/dhcp; /sbin/syslogd ; sleep 2; /sbin/e-smith/signal-event post-install\n" )
323 s = Script(script, interp="/bin/sh", inChroot=1)
324 log.info("%s", s)
325 s.run(anaconda.rootPath, serial)
326 win.pop()
327
328 def setInstallData(self, anaconda):
329 BaseInstallClass.setInstallData(self, anaconda)
330 self.anaconda = anaconda
331 self.setSELinux(anaconda.id, SELINUX_DISABLED)
332
333 def setGroupSelection(self, anaconda):
334 BaseInstallClass.__init__(self, anaconda.backend)
335 anaconda.backend.selectGroup("Base")
336 anaconda.backend.selectGroup("Core")
337 anaconda.backend.selectGroup("Extras")
338 anaconda.backend.selectGroup("SME Server")
339
340 def __init__(self, expert):
341 BaseInstallClass.__init__(self, expert)
342 self.repopaths = { "base": "%s" %(productPath,) }
343 self.forceTextMode = 1

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