From 6d5c8583ecf0cafa139d20a7bfb123c843ad77b8 Mon Sep 17 00:00:00 2001 From: Narayan Desai Date: Sat, 2 Jun 2007 21:00:41 +0000 Subject: Add preliminary support for FreeBSD Packages (from gogo) git-svn-id: https://svn.mcs.anl.gov/repos/bcfg/trunk/bcfg2@3223 ce84e21b-d406-0410-9b95-82705330c041 --- src/lib/Client/Frame.py | 3 ++- src/lib/Client/Tools/FreeBSDPackage.py | 42 ++++++++++++++++++++++++++++++++++ src/lib/Client/Tools/__init__.py | 5 ++-- 3 files changed, 47 insertions(+), 3 deletions(-) create mode 100644 src/lib/Client/Tools/FreeBSDPackage.py (limited to 'src') diff --git a/src/lib/Client/Frame.py b/src/lib/Client/Frame.py index b069978a8..f685e7491 100644 --- a/src/lib/Client/Frame.py +++ b/src/lib/Client/Frame.py @@ -31,7 +31,8 @@ toolset_defs = {'rh': {'Service':'chkconfig', 'Package':'rpm'}, 'debian': {'Service':'deb', 'Package':'deb'}, 'nexenta': {'Service':'smf', 'Package':'deb'}, 'solaris': {'Service':'smf', 'Package':'sysv'}, - 'gentoo': {'Service':'rc-update', 'Package':'ebuild'}} + 'gentoo': {'Service':'rc-update', 'Package':'ebuild'}, + 'freebsd': {'Package':'freebsdpkg'}} class Frame: '''Frame is the container for all Tool objects and state information''' diff --git a/src/lib/Client/Tools/FreeBSDPackage.py b/src/lib/Client/Tools/FreeBSDPackage.py new file mode 100644 index 000000000..0e8747e8b --- /dev/null +++ b/src/lib/Client/Tools/FreeBSDPackage.py @@ -0,0 +1,42 @@ +'''This is the bcfg2 tool for the FreeBSD package system.''' +__revision__ = '$Id$' + +import re +import Bcfg2.Client.Tools + +class FreeBSDPackage(Bcfg2.Client.Tools.PkgTool): + '''The FreeBSD toolset implements package operations and inherits + the rest from Toolset.Toolset''' + __name__ = 'FreeBSDPackage' + __execs__ = ['/usr/sbin/pkg_add', '/usr/sbin/pkg_info'] + __handles__ = [('Package', 'freebsdpkg')] + __req__ = {'Package': ['name', 'version']} + pkgtool = ('/usr/sbin/pkg_add -r %s', ('%s-%s', ['name', 'version'])) + pkgtype = 'freebsdpkg' + + def RefreshPackages(self): + self.installed = {} + packages = self.cmd.run("/usr/sbin/pkg_info -a -E")[1] + pattern = re.compile('(.*)-(\d.*)') + for pkg in packages: + if pattern.match(pkg): + name = pattern.match(pkg).group(1) + version = pattern.match(pkg).group(2) + self.installed[name] = version + + def VerifyPackage(self, entry, modlist): + if not entry.attrib.has_key('version'): + self.logger.info("Cannot verify unversioned package %s" % + (entry.attrib['name'])) + return False + if self.installed.has_key(entry.attrib['name']): + if self.installed[entry.attrib['name']] == entry.attrib['version']: + # TODO: verfification + return True + else: + entry.set('current_version', self.installed[entry.get('name')]) + return False + + self.logger.info("Package %s not installed" % (entry.get('name'))) + entry.set('current_exists', 'false') + return False diff --git a/src/lib/Client/Tools/__init__.py b/src/lib/Client/Tools/__init__.py index a4a2dc08c..1ab656481 100644 --- a/src/lib/Client/Tools/__init__.py +++ b/src/lib/Client/Tools/__init__.py @@ -2,8 +2,9 @@ __revision__ = '$Revision$' __all__ = ["Action", "APT", "Blast", "Chkconfig", "DebInit", "Encap", - "launchd", "Portage", "POSIX", "RPM", "RPMng", 'rpmtools', - "RcUpdate", "SMF", "SYSV", "Yum", "YUMng"] + "FreeBSDPackage", "launchd", "Portage", "POSIX", "RPM", + "RPMng", 'rpmtools', "RcUpdate", "SMF", "SYSV", "Yum", + "YUMng"] drivers = [item for item in __all__ if item not in ['rpmtools']] default = [item for item in drivers if item not in ['RPMng', 'YUMng']] -- cgit v1.2.3-1-g7c22