Qubes class fixups
* Ensure this is the only class * Skip installation steps that make no sense for Qubes
This commit is contained in:
parent
ef4af12841
commit
85b30a5f4c
@ -1,132 +0,0 @@
|
|||||||
#
|
|
||||||
# fedora.py
|
|
||||||
#
|
|
||||||
# Copyright (C) 2007 Red Hat, Inc. All rights reserved.
|
|
||||||
#
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
#
|
|
||||||
|
|
||||||
from installclass import BaseInstallClass
|
|
||||||
from constants import *
|
|
||||||
from product import *
|
|
||||||
from meh.filer import *
|
|
||||||
from flags import flags
|
|
||||||
import os, types
|
|
||||||
import iutil
|
|
||||||
|
|
||||||
import gettext
|
|
||||||
_ = lambda x: gettext.ldgettext("anaconda", x)
|
|
||||||
|
|
||||||
import installmethod
|
|
||||||
import yuminstall
|
|
||||||
|
|
||||||
import rpmUtils.arch
|
|
||||||
|
|
||||||
class InstallClass(BaseInstallClass):
|
|
||||||
# name has underscore used for mnemonics, strip if you dont need it
|
|
||||||
id = "fedora"
|
|
||||||
name = N_("_Fedora")
|
|
||||||
_description = N_("The default installation of %s includes a set of "
|
|
||||||
"software applicable for general internet usage. "
|
|
||||||
"You can optionally select a different set of software "
|
|
||||||
"now.")
|
|
||||||
_descriptionFields = (productName,)
|
|
||||||
sortPriority = 10000
|
|
||||||
if productName.startswith("Red Hat Enterprise"):
|
|
||||||
hidden = 1
|
|
||||||
|
|
||||||
tasks = [(N_("Graphical Desktop"),
|
|
||||||
["admin-tools", "base", "base-x", "core", "editors", "fonts",
|
|
||||||
"games", "gnome-desktop", "graphical-internet", "graphics",
|
|
||||||
"hardware-support", "input-methods", "java", "office",
|
|
||||||
"printing", "sound-and-video", "text-internet"]),
|
|
||||||
(N_("Software Development"),
|
|
||||||
["base", "base-x", "core", "development-libs",
|
|
||||||
"development-tools", "editors", "fonts", "gnome-desktop",
|
|
||||||
"gnome-software-development", "graphical-internet", "graphics",
|
|
||||||
"hardware-support", "input-methods", "java", "text-internet",
|
|
||||||
"x-software-development"]),
|
|
||||||
(N_("Web Server"),
|
|
||||||
["admin-tools", "base", "base-x", "core", "editors",
|
|
||||||
"gnome-desktop", "graphical-internet", "hardware-support",
|
|
||||||
"java", "text-internet", "web-server"]),
|
|
||||||
(N_("Minimal"), ["core"])]
|
|
||||||
|
|
||||||
bugFiler = BugzillaFiler("https://bugzilla.redhat.com/xmlrpc.cgi",
|
|
||||||
"https://bugzilla.redhat.com/",
|
|
||||||
product.productVersion, product.productName)
|
|
||||||
|
|
||||||
def getPackagePaths(self, uri):
|
|
||||||
if not type(uri) == types.ListType:
|
|
||||||
uri = [uri,]
|
|
||||||
|
|
||||||
return {'Installation Repo': uri}
|
|
||||||
|
|
||||||
def configure(self, anaconda):
|
|
||||||
BaseInstallClass.configure(self, anaconda)
|
|
||||||
BaseInstallClass.setDefaultPartitioning(self,
|
|
||||||
anaconda.storage,
|
|
||||||
anaconda.platform)
|
|
||||||
|
|
||||||
def setGroupSelection(self, anaconda):
|
|
||||||
BaseInstallClass.setGroupSelection(self, anaconda)
|
|
||||||
map(lambda x: anaconda.backend.selectGroup(x), ["core"])
|
|
||||||
|
|
||||||
def setSteps(self, anaconda):
|
|
||||||
BaseInstallClass.setSteps(self, anaconda)
|
|
||||||
anaconda.dispatch.skipStep("partition")
|
|
||||||
|
|
||||||
def getBackend(self):
|
|
||||||
if flags.livecdInstall:
|
|
||||||
import livecd
|
|
||||||
return livecd.LiveCDCopyBackend
|
|
||||||
else:
|
|
||||||
return yuminstall.YumBackend
|
|
||||||
|
|
||||||
def productMatches(self, oldprod):
|
|
||||||
if oldprod is None:
|
|
||||||
return False
|
|
||||||
|
|
||||||
if oldprod.startswith(productName):
|
|
||||||
return True
|
|
||||||
|
|
||||||
productUpgrades = {
|
|
||||||
"Fedora Core": ("Red Hat Linux", ),
|
|
||||||
"Fedora": ("Fedora Core", )
|
|
||||||
}
|
|
||||||
|
|
||||||
if productUpgrades.has_key(productName):
|
|
||||||
acceptable = productUpgrades[productName]
|
|
||||||
else:
|
|
||||||
acceptable = ()
|
|
||||||
|
|
||||||
for p in acceptable:
|
|
||||||
if oldprod.startswith(p):
|
|
||||||
return True
|
|
||||||
|
|
||||||
return False
|
|
||||||
|
|
||||||
def versionMatches(self, oldver):
|
|
||||||
try:
|
|
||||||
oldVer = float(oldver)
|
|
||||||
newVer = float(productVersion)
|
|
||||||
except ValueError:
|
|
||||||
return True
|
|
||||||
|
|
||||||
# This line means we do not support upgrading from anything older
|
|
||||||
# than two versions ago!
|
|
||||||
return newVer > oldVer and newVer - oldVer <= 2
|
|
||||||
|
|
||||||
def __init__(self):
|
|
||||||
BaseInstallClass.__init__(self)
|
|
@ -1,7 +1,7 @@
|
|||||||
#
|
#
|
||||||
# qubes.py
|
# qubes.py
|
||||||
#
|
#
|
||||||
# Copyright (C) 2007 Red Hat, Inc. All rights reserved.
|
# Copyright (C) 2011 Invisible Things Lab All rights reserved.
|
||||||
#
|
#
|
||||||
# This program is free software; you can redistribute it and/or modify
|
# This program is free software; you can redistribute it and/or modify
|
||||||
# it under the terms of the GNU General Public License as published by
|
# it under the terms of the GNU General Public License as published by
|
||||||
@ -83,6 +83,12 @@ class InstallClass(BaseInstallClass):
|
|||||||
def setSteps(self, anaconda):
|
def setSteps(self, anaconda):
|
||||||
BaseInstallClass.setSteps(self, anaconda)
|
BaseInstallClass.setSteps(self, anaconda)
|
||||||
anaconda.dispatch.skipStep("partition")
|
anaconda.dispatch.skipStep("partition")
|
||||||
|
anaconda.dispatch.skipStep("language")
|
||||||
|
anaconda.dispatch.skipStep("reposetup")
|
||||||
|
anaconda.dispatch.skipStep("tasksel")
|
||||||
|
anaconda.dispatch.skipStep("basepkgsel")
|
||||||
|
anaconda.dispatch.skipStep("group-selection")
|
||||||
|
anaconda.dispatch.skipStep("postselection")
|
||||||
|
|
||||||
def getBackend(self):
|
def getBackend(self):
|
||||||
if flags.livecdInstall:
|
if flags.livecdInstall:
|
||||||
@ -92,27 +98,6 @@ class InstallClass(BaseInstallClass):
|
|||||||
return yuminstall.YumBackend
|
return yuminstall.YumBackend
|
||||||
|
|
||||||
def productMatches(self, oldprod):
|
def productMatches(self, oldprod):
|
||||||
if oldprod is None:
|
|
||||||
return False
|
|
||||||
|
|
||||||
if oldprod.startswith(productName):
|
|
||||||
return True
|
|
||||||
|
|
||||||
productUpgrades = {
|
|
||||||
"Fedora Core": ("Red Hat Linux", ),
|
|
||||||
"Fedora": ("Fedora Core", ),
|
|
||||||
"Qubes": ("Fedora", )
|
|
||||||
}
|
|
||||||
|
|
||||||
if productUpgrades.has_key(productName):
|
|
||||||
acceptable = productUpgrades[productName]
|
|
||||||
else:
|
|
||||||
acceptable = ()
|
|
||||||
|
|
||||||
for p in acceptable:
|
|
||||||
if oldprod.startswith(p):
|
|
||||||
return True
|
|
||||||
|
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def versionMatches(self, oldver):
|
def versionMatches(self, oldver):
|
||||||
|
@ -1,160 +0,0 @@
|
|||||||
#
|
|
||||||
# rhel.py
|
|
||||||
#
|
|
||||||
# Copyright (C) 2007 Red Hat, Inc. All rights reserved.
|
|
||||||
#
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
#
|
|
||||||
|
|
||||||
from installclass import BaseInstallClass
|
|
||||||
from constants import *
|
|
||||||
from product import *
|
|
||||||
from meh.filer import *
|
|
||||||
from flags import flags
|
|
||||||
import os
|
|
||||||
import types
|
|
||||||
import iutil
|
|
||||||
|
|
||||||
import gettext
|
|
||||||
_ = lambda x: gettext.ldgettext("anaconda", x)
|
|
||||||
|
|
||||||
import installmethod
|
|
||||||
import yuminstall
|
|
||||||
|
|
||||||
import rpmUtils.arch
|
|
||||||
|
|
||||||
class InstallClass(BaseInstallClass):
|
|
||||||
# name has underscore used for mnemonics, strip if you dont need it
|
|
||||||
id = "rhel"
|
|
||||||
name = N_("Red Hat Enterprise Linux")
|
|
||||||
_description = N_("The default installation of %s is a minimal install. "
|
|
||||||
"You can optionally select a different set of software "
|
|
||||||
"now.")
|
|
||||||
_descriptionFields = (productName,)
|
|
||||||
sortPriority = 10000
|
|
||||||
if not productName.startswith("Red Hat Enterprise"):
|
|
||||||
hidden = 1
|
|
||||||
|
|
||||||
bootloaderTimeoutDefault = 5
|
|
||||||
|
|
||||||
tasks = [(N_("Minimal"), ["core"]),
|
|
||||||
(N_("Desktop"),
|
|
||||||
["backup-client", "base", "compat-libraries", "console-internet",
|
|
||||||
"debugging", "directory-client", "fonts",
|
|
||||||
"legacy-unix", "core", "network-file-system-client",
|
|
||||||
"network-tools", "print-client", "virtualization", "vpn",
|
|
||||||
"basic-desktop", "desktop-debugging", "desktop-platform",
|
|
||||||
"general-desktop", "graphical-admin-tools", "input-methods",
|
|
||||||
"legacy-x", "x11","office-suite", "graphics",
|
|
||||||
"virtualization-client"]),
|
|
||||||
(N_("Software Development"),
|
|
||||||
["backup-client", "base", "compat-libraries", "console-internet",
|
|
||||||
"debugging", "directory-client", "fonts",
|
|
||||||
"legacy-unix", "core", "network-file-system-client",
|
|
||||||
"network-tools", "print-client", "virtualization", "vpn",
|
|
||||||
"basic-desktop", "desktop-debugging", "desktop-platform",
|
|
||||||
"general-desktop", "graphical-admin-tools", "input-methods",
|
|
||||||
"legacy-x", "x11", "virtualization-client", "emacs", "tex",
|
|
||||||
"desktop-platform-devel", "development", "eclipse",
|
|
||||||
"server-platform-devel", "technical-writing"]),
|
|
||||||
(N_("Web Server"),
|
|
||||||
["backup-client", "base", "compat-libraries", "console-internet",
|
|
||||||
"debugging", "directory-client", "legacy-unix",
|
|
||||||
"core", "network-file-system-client", "network-tools",
|
|
||||||
"web-server", "additional-web-server", "server-platform",
|
|
||||||
"mysql", "php", "postgresql", "rails", "turbogears",
|
|
||||||
"system-admin-tools"]),
|
|
||||||
(N_("Advanced Server"),
|
|
||||||
["backup-client", "base", "compat-libraries", "console-internet",
|
|
||||||
"debugging", "directory-client", "legacy-unix",
|
|
||||||
"core", "network-file-system-client", "network-tools",
|
|
||||||
"web-server", "server-platform",
|
|
||||||
"mysql", "php", "postgresql", "rails", "turbogears",
|
|
||||||
"cifs-file-server", "clustering", "clustered-storage",
|
|
||||||
"directory-server", "mail-server", "ftp-server",
|
|
||||||
"network-server", "nfs-file-server", "print-server",
|
|
||||||
"system-admin-tools"])]
|
|
||||||
|
|
||||||
bugFiler = BugzillaFiler("https://bugzilla.redhat.com/xmlrpc.cgi",
|
|
||||||
"https://bugzilla.redhat.com/",
|
|
||||||
product.productVersion, product.productName)
|
|
||||||
|
|
||||||
def getPackagePaths(self, uri):
|
|
||||||
if not type(uri) == types.ListType:
|
|
||||||
uri = [uri,]
|
|
||||||
|
|
||||||
return {'Installation Repo': uri}
|
|
||||||
|
|
||||||
def configure(self, anaconda):
|
|
||||||
BaseInstallClass.configure(self, anaconda)
|
|
||||||
BaseInstallClass.setDefaultPartitioning(self,
|
|
||||||
anaconda.storage,
|
|
||||||
anaconda.platform)
|
|
||||||
|
|
||||||
def setGroupSelection(self, anaconda):
|
|
||||||
BaseInstallClass.setGroupSelection(self, anaconda)
|
|
||||||
map(lambda x: anaconda.backend.selectGroup(x), ["core"])
|
|
||||||
|
|
||||||
def setSteps(self, anaconda):
|
|
||||||
BaseInstallClass.setSteps(self, anaconda)
|
|
||||||
anaconda.dispatch.skipStep("partition")
|
|
||||||
|
|
||||||
def getBackend(self):
|
|
||||||
if flags.livecdInstall:
|
|
||||||
import livecd
|
|
||||||
return livecd.LiveCDCopyBackend
|
|
||||||
else:
|
|
||||||
return yuminstall.YumBackend
|
|
||||||
|
|
||||||
def productMatches(self, oldprod):
|
|
||||||
if oldprod is None:
|
|
||||||
return False
|
|
||||||
|
|
||||||
if oldprod.startswith(productName):
|
|
||||||
return True
|
|
||||||
|
|
||||||
productUpgrades = {
|
|
||||||
"Red Hat Enterprise Linux AS": ("Red Hat Linux Advanced Server", ),
|
|
||||||
"Red Hat Enterprise Linux WS": ("Red Hat Linux Advanced Workstation",),
|
|
||||||
# FIXME: this probably shouldn't be in a release...
|
|
||||||
"Red Hat Enterprise Linux": ("Red Hat Linux Advanced Server",
|
|
||||||
"Red Hat Linux Advanced Workstation",
|
|
||||||
"Red Hat Enterprise Linux AS",
|
|
||||||
"Red Hat Enterprise Linux ES",
|
|
||||||
"Red Hat Enterprise Linux WS"),
|
|
||||||
"Red Hat Enterprise Linux Server": ("Red Hat Enterprise Linux AS",
|
|
||||||
"Red Hat Enterprise Linux ES",
|
|
||||||
"Red Hat Enterprise Linux WS",
|
|
||||||
"Red Hat Enterprise Linux"),
|
|
||||||
"Red Hat Enterprise Linux Client": ("Red Hat Enterprise Linux WS",
|
|
||||||
"Red Hat Enterprise Linux Desktop",
|
|
||||||
"Red Hat Enterprise Linux"),
|
|
||||||
}
|
|
||||||
|
|
||||||
if productUpgrades.has_key(productName):
|
|
||||||
acceptable = productUpgrades[productName]
|
|
||||||
else:
|
|
||||||
acceptable = ()
|
|
||||||
|
|
||||||
for p in acceptable:
|
|
||||||
if oldprod.startswith(p):
|
|
||||||
return True
|
|
||||||
|
|
||||||
return False
|
|
||||||
|
|
||||||
def versionMatches(self, oldver):
|
|
||||||
return True
|
|
||||||
|
|
||||||
def __init__(self):
|
|
||||||
BaseInstallClass.__init__(self)
|
|
Loading…
Reference in New Issue
Block a user