# # pylorax # Install image and tree support data generation tool -- Python module. # # Copyright (C) 2008 Red Hat, Inc. # # 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 . # # Author(s): David Cantrell # version = (0, 1) __all__ = ['discinfo', 'treeinfo', 'instroot'] import os import shutil import tempfile import yum import rpmUtils import discinfo import treeinfo import instroot conf = {} conf['confdir'] = '/etc/lorax' def show_version(prog): """show_version(prog) Display program name (prog) and version number. If prog is an empty string or None, use the value 'pylorax'. """ if prog is None or prog == '': prog = 'pylorax' print "%s version %d.%d" % (prog, version[0], version[1],) def collectRepos(args): """collectRepos(args) Get the main repo (the first one) and then build a list of all remaining repos in the list. Sanitize each repo URL for proper yum syntax. """ if args is None or args == []: return '', [] repolist = [] for repospec in args: if repospec.startswith('/'): repolist.append("file://%s" % (repospec,)) elif repospec.startswith('http://') or repospec.startswith('ftp://'): repolist.append(repospec) repo = repolist[0] extrarepos = [] if len(repolist) > 1: for extra in repolist[1:]: extrarepos.append(extra) return repo, extrarepos def initializeDirs(output): """initializeDirs(output) Create directories used for image generation. The only required parameter is the main output directory specified by the user. """ if not os.path.isdir(output): os.makedirs(output, mode=0755) tmpdir = tempfile.gettempdir() buildinstdir = tempfile.mkdtemp('XXXXXX', 'buildinstall.tree.', tmpdir) treedir = tempfile.mkdtemp('XXXXXX', 'treedir.', tmpdir) cachedir = tempfile.mkdtemp('XXXXXX', 'yumcache.', tmpdir) return buildinstdir, treedir, cachedir def writeYumConf(cachedir=None, repo=None, extrarepos=[], mirrorlist=[]): """writeYumConf(cachedir=None, repo=None, [extrarepos=[], mirrorlist=[]]) Generate a temporary yum.conf file for image generation. The required parameters are the cachedir that yum should use and the main repo to use. Optional parameters are a list of extra repositories to add to the yum.conf file. The mirrorlist parameter is a list of yum mirrorlists that should be added to the yum.conf file. Returns the path to the temporary yum.conf file on success, None of failure. """ if cachedir is None or repo is None: return None tmpdir = tempfile.gettempdir() (fd, yumconf) = tempfile.mkstemp(prefix='yum.conf', dir=tmpdir) f = os.fdopen(fd, 'w') f.write("[main]\n") f.write("cachedir=%s\n" % (cachedir,)) f.write("keepcache=0\n") f.write("gpgcheck=0\n") f.write("plugins=0\n") f.write("reposdir=\n") f.write("tsflags=nodocs\n\n") f.write("[anacondarepo]\n") f.write("name=anaconda repo\n") f.write("baseurl=%s\n" % (repo,)) f.write("enabled=1\n\n") if extrarepos != []: n = 1 for extra in extrarepos: f.write("[anaconda-extrarepo-%d]\n" % (n,)) f.write("name=anaconda extra repo %d\n" % (n,)) f.write("baseurl=%s\n" % (extra,)) f.write("enabled=1\n") n += 1 if mirrorlist != []: n = 1 for mirror in mirrorlist: f.write("[anaconda-mirrorlistrepo-%d]\n" % (n,)) f.write("name=anaconda mirrorlist repo %d\n" % (n,)) f.write("mirrorlist=%s\n" % (extra,)) f.write("enabled=1\n") n += 1 f.close() return yumconf def getBuildArch(yumconf=None): """getBuildArch(yumconf=None) Query the configured yum repositories to determine our build architecture, which is the architecture of the anaconda package in the repositories. The required argument is yumconf, which is the path to the yum configuration file to use. This function is based on a subset of what repoquery(1) does. """ uname_arch = os.uname()[4] if yumconf == '' or yumconf is None or not os.path.isfile(yumconf): return uname_arch repoq = yum.YumBase() repoq.doConfigSetup() try: repoq.doRepoSetup() except yum.Errors.RepoError, e: sys.stderr.write("ERROR: could not query yum repository for build arch, defaulting to %s\n" % (uname_arch,)) return uname_arch repoq.doSackSetup(rpmUtils.arch.getArchList()) repoq.doTsSetup() ret_arch = None for pkg in repoq.pkgSack.simplePkgList(): (n, a, e, v, r) = pkg if n == 'anaconda': ret_arch = a break if ret_arch is None: ret_arch = uname_arch return ret_arch def cleanup(trash=[]): """cleanup(trash) Given a list of things to remove, cleanup() will remove them if it can. Never fails, just tries to remove things and returns regardless of failures removing things. """ if trash is []: return for item in trash: if os.path.isdir(item): shutil.rmtree(item, ignore_errors=True) else: os.unlink(item) return