From d45ae01ad674aa2b52774d4c991c912f414f8cf6 Mon Sep 17 00:00:00 2001 From: Fabian Affolter Date: Tue, 11 Oct 2011 23:05:25 +0200 Subject: Minor changes --- src/lib/Client/Tools/APT.py | 4 ++-- src/lib/Client/Tools/Blast.py | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) (limited to 'src/lib/Client') diff --git a/src/lib/Client/Tools/APT.py b/src/lib/Client/Tools/APT.py index b2b8120ba..d268fe9f4 100644 --- a/src/lib/Client/Tools/APT.py +++ b/src/lib/Client/Tools/APT.py @@ -1,4 +1,4 @@ -"""This is the bcfg2 support for apt-get""" +"""This is the Bcfg2 support for apt-get.""" __revision__ = '$Revision$' # suppress apt API warnings @@ -238,5 +238,5 @@ class APT(Bcfg2.Client.Tools.Tool): self.modified.append(package) def VerifyPath(self, entry, _): - """Do nothing here since we only verify Path type=ignore""" + """Do nothing here since we only verify Path type=ignore.""" return True diff --git a/src/lib/Client/Tools/Blast.py b/src/lib/Client/Tools/Blast.py index 4f2891fd6..29cdfa116 100644 --- a/src/lib/Client/Tools/Blast.py +++ b/src/lib/Client/Tools/Blast.py @@ -1,5 +1,5 @@ # This is the bcfg2 support for blastwave packages (pkg-get) -"""This provides bcfg2 support for blastwave""" +"""This provides Bcfg2 support for Blastwave.""" __revision__ = '$Revision$' import tempfile @@ -7,7 +7,7 @@ import Bcfg2.Client.Tools.SYSV class Blast(Bcfg2.Client.Tools.SYSV.SYSV): - """Support for Blastwave packages""" + """Support for Blastwave packages.""" pkgtype = 'blast' pkgtool = ("/opt/csw/bin/pkg-get install %s", ("%s", ["bname"])) name = 'Blast' -- cgit v1.2.3-1-g7c22 From 819bbdcacc0e9021d49fed9d003be3bc1d5be40a Mon Sep 17 00:00:00 2001 From: Fabian Affolter Date: Tue, 11 Oct 2011 23:14:04 +0200 Subject: Initial support for the APK management in Alpine Linux. This is highly experimental. All credits goes to Cameron Banta. --- src/lib/Client/Tools/APK.py | 58 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 src/lib/Client/Tools/APK.py (limited to 'src/lib/Client') diff --git a/src/lib/Client/Tools/APK.py b/src/lib/Client/Tools/APK.py new file mode 100644 index 000000000..5add7b7b4 --- /dev/null +++ b/src/lib/Client/Tools/APK.py @@ -0,0 +1,58 @@ +"""This provides Bcfg2 support for Alpine Linux APK packages.""" +__revision__ = '$Revision$' + +import Bcfg2.Client.Tools + +class APK(Bcfg2.Client.Tools.PkgTool): + """Support for Apk packages.""" + name = 'APK' + __execs__ = ["/sbin/apk"] + __handles__ = [('Package', 'apk')] + __req__ = {'Package': ['name', 'version']} + pkgtype = 'apk' + pkgtool = ("/sbin/apk add %s", ("%s", ["name"])) + + def __init__(self, logger, setup, config): + Bcfg2.Client.Tools.PkgTool.__init__(self, logger, setup, config) + self.installed = {} + self.RefreshPackages() + + def RefreshPackages(self): + """Refresh memory hashes of packages.""" + names = self.cmd.run("/sbin/apk info")[1] + nameversions = self.cmd.run("/sbin/apk info -v")[1] + for pkg in zip(names, nameversions): + pkgname = pkg[0] + version = pkg[1][len(pkgname)+1:] + self.logger.debug(" pkgname: %s\n version: %s" % (pkgname, version)) + self.installed[pkgname] = version + + def VerifyPackage(self, entry, modlist): + """Verify Package status for entry.""" + if not 'version' in entry.attrib: + self.logger.info("Cannot verify unversioned package %s" % + (entry.attrib['name'])) + return False + + if entry.attrib['name'] in self.installed: + if entry.attrib['version'] == 'auto' or self.installed[entry.attrib['name']] == entry.attrib['version']: + #if not self.setup['quick'] and \ + # entry.get('verify', 'true') == 'true': + #FIXME: We should be able to check this once + # http://trac.macports.org/ticket/15709 is implemented + return True + else: + self.loggger.info( " pkg %s at version %s, not %s" % (entry.attrib['name'],self.installed[entry.attrib['name']],entry.attrib['version']) ) + entry.set('current_version', self.installed[entry.get('name')]) + return False + entry.set('current_exists', 'false') + return False + + def RemovePackages(self, packages): + """Remove extra packages.""" + names = [pkg.get('name') for pkg in packages] + self.logger.info("Removing packages: %s" % " ".join(names)) + self.cmd.run("/sbin/apk del %s" % \ + " ".join(names)) + self.RefreshPackages() + self.extra = self.FindExtraPackages() -- cgit v1.2.3-1-g7c22