diff options
author | Joel Andres Granados <jgranado@redhat.com> | 2008-03-17 19:19:48 +0100 |
---|---|---|
committer | Joel Andres Granados <jgranado@redhat.com> | 2008-03-17 19:19:48 +0100 |
commit | 590fc4aa9d28bbbb788f6a6071a58688c4f68931 (patch) | |
tree | 26a87d7100ea5fa8c58707eff438b11204f9e151 /plugins/xserver.py | |
parent | bd2811513cb2df737f90dfa309d2f8fed58510a4 (diff) | |
download | firstaidkit-590fc4aa9d28bbbb788f6a6071a58688c4f68931.tar.gz firstaidkit-590fc4aa9d28bbbb788f6a6071a58688c4f68931.tar.xz firstaidkit-590fc4aa9d28bbbb788f6a6071a58688c4f68931.zip |
xserver plugin
Diffstat (limited to 'plugins/xserver.py')
-rw-r--r-- | plugins/xserver.py | 123 |
1 files changed, 123 insertions, 0 deletions
diff --git a/plugins/xserver.py b/plugins/xserver.py new file mode 100644 index 0000000..c25e06c --- /dev/null +++ b/plugins/xserver.py @@ -0,0 +1,123 @@ +# First Aid Kit - diagnostic and repair tool for Linux +# Copyright (C) 2008 Joel Andres Granados <jgranado@redhat.com> +# +# 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, write to the Free Software +# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + +from pyfirstaidkit.plugins import Plugin,Flow +from pyfirstaidkit.returns import * +from pyfirstaidkit.reporting import PLUGIN +from pyfirstaidkit import Config + +import rhpxl.xserver +import rhpl.keyboard +import temp +import subprocess +import time +import signal +import os +import shutil + +class Xserver(Plugin): + """ Plugin to detect an rescue faulty xserver configurations. """ + + name = "X server" + version = "0.0.1" + author = "Joel Andres Granados" + def __init__(self, *args, **kwargs): + Plugin.__init__(self, *args, **kwargs) + # Arbitrary test display + self.display = ":10" + # For when we need a temporary log. + (self.tmpLogfd, self.tmpLogPath) = temp.mktemp() + self.confPath = "/etc/X11/xorg.conf" + + def prepare(self): + # Nothing to prepare really. + self._result = ReturnSuccess + + # If we cant start the server + def diagnose(self): + if self.serverStart(): + self._reporting.info("Everything seems ok with the X server.", level = PLUGIN, origin = self) + self._result = ReturnSuccess + else: + self._reporting.info("X server is missconfigured.", level = PLUGIN, origin = self) + self._result = ReturnFailure + + # FIXME:Must change this when the backup utils is done. + def backup(self): + if os.isfile(self.confPath): + self._reporting.info("Making copy of %s"%self.confPath, level = PLUGIN , origin = self) + shutil.copyfile(self.confPath, "%s.FAK-backup"%self.confPath) + else: + self._reporting.info("Expected path to configuration file seems to be nonexistent (%s)"% + self.confPath, level = PLUGIN, origin = self) + + def fix(self): + self._reporting.info("Starting the fix task.", level = PLUGIN, origin = self) + xserver = rhpxl.xserver.XServer() + self._reporting.info("Probing for HardWare.", level = PLUGIN, origin = self) + xserver.probeHW() + xserver.setHWState() + xserver.keyboard = rhpl.keyboard.Keyboard() + self._reporting.info("Generating configuration file.", level = PLUGIN, origin = self) + xserver.generateCconfig() + self._reporting.info("Writing configuration file to %s."%self.confPath, level = PLUGIN, origin = self) + xserver.writeConfig(self.confPath) + + self._reporting.info("Testing created file", leve = PLUGIN, origin = self) + if self.serverStart(): + self._reporting.info("X server started successfully with new file.", level = PLUGIN, origin = self) + self._result = ReturnSuccess + else: + self._reporting.info("X server is still missconfigured with new file.", level = PLUGIN, origin = self) + self._result = ReturnFailure + + def restore(self): + if os.isfile("%.FAK-backup"%self.confPath): + self._reporting.info("Restoring original file.", level = PLUGIN , origin = self) + shutil.copyfile("%s.FAK-backup"%self.confPath, self.confPath) + else: + self._reporting.info("The backed up file was not present, something strange is going on."% + self.confPath, level = PLUGIN, origin = self) + + def clean(self): + self._reporting.info("Cleaning the backed up file.", level = PLUGIN, origin = self) + if os.isfile("%.FAK-backup"%self.confPath): + os.rmfile("%.FAK-backup"%self.confPath) + + + + def serverStart(self): + self._reporting.info("Trying to start X server", level = PLUGIN, origin = self) + xorgargs = ["--logfile", self.tmpLogPath, self.display] + try: + proc = spawnvch(executable = "/usr/bin/Xorg", args = xorgargs, chroot = Config.system.root) + self._reporting.info("Waiting for the X server to start...", level = PLUGIN, origin = self) + time.sleep(5) + if proc.poll() is not None: + # process has terminated, failed. + raise OSError + except: + self._reporting.info("The X server has failed to start", level = PLUGIN, origin = self) + return False + self._reporting.info("The X server has started successfully", level = PLUGIN, origin = self) + os.kill(proc.pid, signal.SIG_INT) + return True + + +def get_plugin(): + return Xserver() + |