X-Original-To: alpine-devel@lists.alpinelinux.org Delivered-To: alpine-devel@lists.alpinelinux.org Received: from mail-gx0-f182.google.com (mail-gx0-f182.google.com [209.85.161.182]) by lists.alpinelinux.org (Postfix) with ESMTP id 998051EBFEE for ; Wed, 17 Nov 2010 16:12:08 +0000 (UTC) Received: by gxk9 with SMTP id 9so1220995gxk.13 for ; Wed, 17 Nov 2010 08:12:07 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=domainkey-signature:received:received:from:to:cc:subject:date :message-id:x-mailer; bh=9WqDYcNxCzhN1HxKwUQAdHF9aXq19I0vpmdlF3QYdr0=; b=xdYGYxGXEd3L31lQ14hGANUdP3S4tYMu1Ez/xNLoCm2YNo5MxbthuWoyycycQldndv vQ+Vfg2j0EExa/i7CzOwl6q63rrYKk09tq0LibJvY5PSQM9ejcrMnJFKOSp7Ko/UqI1l z6yt//ZfvA03VCP/SueaEmz2o1iZ88F436Jz4= DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=from:to:cc:subject:date:message-id:x-mailer; b=rXPBe9msL0r0dKpM7SfKlhjoOuMFz5auUo4wRD2plflnG4zBVIt+D1F4F5bkwW3a+q G5d5DgDwg/UHOywbzdwCHOcubSpBCiLdzf7dYdv62sAkYOeheG4JaEeD2ptU007ZCUPo TfuYJIU63mUDestKf1j7ZQldJ5z8zm+gnZH8g= Received: by 10.150.225.14 with SMTP id x14mr7271446ybg.132.1290010327679; Wed, 17 Nov 2010 08:12:07 -0800 (PST) Received: from localhost.localdomain (c-71-228-19-24.hsd1.il.comcast.net [71.228.19.24]) by mx.google.com with ESMTPS id 5sm1685042yhl.47.2010.11.17.08.12.05 (version=TLSv1/SSLv3 cipher=RC4-MD5); Wed, 17 Nov 2010 08:12:06 -0800 (PST) From: Cameron Banta To: alpine-devel@lists.alpinelinux.org Cc: Cameron Banta Subject: [alpine-devel] [PATCH] testing/bcfg2 new package Date: Wed, 3 Nov 2010 17:29:28 +0000 Message-Id: <1288805368-2382-1-git-send-email-cbanta@gmail.com> X-Mailer: git-send-email 1.7.3.2 X-Mailinglist: alpine-devel Precedence: list List-Id: Alpine Development List-Unsubscribe: List-Post: List-Help: List-Subscribe: --- testing/bcfg2/APK.py | 58 ++++++++++++++++++++++++++++++++++++++ testing/bcfg2/APKBUILD | 40 ++++++++++++++++++++++++++ testing/bcfg2/bcfg2-server.initd | 23 +++++++++++++++ 3 files changed, 121 insertions(+), 0 deletions(-) create mode 100644 testing/bcfg2/APK.py create mode 100644 testing/bcfg2/APKBUILD create mode 100644 testing/bcfg2/bcfg2-server.initd diff --git a/testing/bcfg2/APK.py b/testing/bcfg2/APK.py new file mode 100644 index 0000000..9b28d52 --- /dev/null +++ b/testing/bcfg2/APK.py @@ -0,0 +1,58 @@ +"""This provides Bcfg2 support for alpinelinux APK packages.""" +__revision__ = '$Revision$' + +import Bcfg2.Client.Tools + +class APK(Bcfg2.Client.Tools.PkgTool): + """apk package support.""" + 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() diff --git a/testing/bcfg2/APKBUILD b/testing/bcfg2/APKBUILD new file mode 100644 index 0000000..7f45976 --- /dev/null +++ b/testing/bcfg2/APKBUILD @@ -0,0 +1,40 @@ +# Contributor: Cameron Banta +# Maintainer: Cameron Banta +pkgname=bcfg2 +pkgver=1.1.1 +pkgrel=0 +pkgdesc="configuration management tool" +url="trac.mcs.anl.gov/project/bcfg2" +license="Custom" +depends="python" +makedepends="python-dev" +install= +subpackages="$pkgname-doc $pkgname-server" +source="ftp://ftp.mcs.anl.gov/pub/bcfg/$pkgname-$pkgver.tar.gz + bcfg2-server.initd + APK.py" + +#no build needed - pure python + +package() { + cd "$srcdir"/$pkgname-$pkgver + cp "$srcdir"/APK.py src/lib/Client/Tools/ + python setup.py bdist_dumb --keep-temp --bdist-dir "$pkgdir" + + install -m644 -D COPYRIGHT "$pkgdir"/usr/share/licenses/$pkgname/COPYRIGHT +} + +server() { + depends="python bcfg2 py-lxml openssl" + + mkdir -p "$subpkgdir"/usr/bin + mv "$pkgdir"/usr/bin/bcfg2-* "$subpkgdir"/usr/bin/ + mkdir -p "$subpkgdir"/usr/share + mv "$pkgdir"/usr/share/bcfg2 "$subpkgdir"/usr/share/ + install -m755 -D bcfg2-server.initd "$subpkgdir"/etc/init.d/$subpkgname +} + + +md5sums="f8889d629245ecf67994469ed78fbfeb bcfg2-1.1.1.tar.gz +9a13baa6f40267ff9dbec574967c5068 bcfg2-server.initd +2acc7c5a8a031a3cb25ab3955d8d1fde APK.py" diff --git a/testing/bcfg2/bcfg2-server.initd b/testing/bcfg2/bcfg2-server.initd new file mode 100644 index 0000000..5168f75 --- /dev/null +++ b/testing/bcfg2/bcfg2-server.initd @@ -0,0 +1,23 @@ +#!/sbin/runscript +# +# bcfgd - bcfg configuration daemon +# +# + +depend () { + need net +} + +start () { + ebegin "Starting bcfg2-server" + start-stop-daemon --start --quiet --pidfile /var/run/bcfg2-server.pid \ + --startas /usr/bin/bcfg2-server -- -D /var/run/bcfg2-server.pid + eend $? "Failed to start bcfg2-server" +} + +stop () { + ebegin "Stopping bcfg2-server" + start-stop-daemon --stop --quiet --pidfile /var/run/bcfg2-server.pid \ + --signal INT + eend $? "Failed to stop bcfg2-server" +} -- 1.7.3.2 --- Unsubscribe: alpine-devel+unsubscribe@lists.alpinelinux.org Help: alpine-devel+help@lists.alpinelinux.org ---