aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrhatto <rhatto@370017ae-e619-0410-ac65-c121f96126d4>2009-06-29 00:51:15 +0000
committerrhatto <rhatto@370017ae-e619-0410-ac65-c121f96126d4>2009-06-29 00:51:15 +0000
commita2bd4ca7da5a1658635e8e9d3bf4125a510fbc9d (patch)
treef55188fbf5cf4511fe1119f57e7d3014c79ca695
parent293879e53b2e7a1eac516eaeba492f96de94f622 (diff)
downloadslackbuilds-a2bd4ca7da5a1658635e8e9d3bf4125a510fbc9d.tar.gz
slackbuilds-a2bd4ca7da5a1658635e8e9d3bf4125a510fbc9d.tar.bz2
puppet: adding initscript ; openrc: addin openrc
git-svn-id: svn+slack://slack.fluxo.info/var/svn/slackbuilds@2222 370017ae-e619-0410-ac65-c121f96126d4
-rw-r--r--app/admin/puppet/Manifest34
-rw-r--r--app/admin/puppet/puppet.SlackBuild52
-rw-r--r--app/admin/puppet/rc.puppet.new36
-rw-r--r--app/admin/puppet/rc.puppetmaster.new36
-rw-r--r--app/admin/puppet/slack-required1
-rw-r--r--sys/apps/openrc/Manifest24
-rw-r--r--sys/apps/openrc/openrc-0.5.0.diff27
-rw-r--r--sys/apps/openrc/openrc.SlackBuild257
8 files changed, 449 insertions, 18 deletions
diff --git a/app/admin/puppet/Manifest b/app/admin/puppet/Manifest
index 92326920..40895377 100644
--- a/app/admin/puppet/Manifest
+++ b/app/admin/puppet/Manifest
@@ -2,23 +2,25 @@
Hash: SHA256
DIST puppet-0.24.8.tgz 1099188 MD5 288d46dee00acad64d0f3ecc6d8ba6fa RMD160 edb187da9225c9faee9839a5d644b5c9c91f3d5f SHA1 a871aef6f3e8e060f5109bb022967066e32875be SHA256 9e9dcfdd26f96e0b0b4ca9bcfe6f473c679ff082a0cd7226c2058ae652d4fdc8 SHA512 bbcfb92c073cc20f2a74e923f79316e4bf829da26ad8b590563ac1cf9cda6fbc7eb541a2c0c26a527a66ee15a146d557833635a67efdaca3f8eccdf63b4d62a3
-MKBUILD puppet.mkbuild 5102 MD5 67060150a08c3e9726f1f970b18e0eb8 RMD160 5c75a8f38e23a9db64b02e6994415dcb65b18ffd SHA1 21c4370ce7dd38814b4c5f1093823ca5718ae877 SHA256 e02a968dd120f3bb8122f71a0298b26e169dd56452ebcec320d107f8c5880c0b SHA512 38a7cc7f3e43acc0248207a77d31c311b1b49aae30fbd3432bf831b52902cc200bb9cc2a063e9ffe164fa59b4149d78e2c8e63b8a62d57f5ae9f1692f4a5d194
-SLACK-REQUIRED slack-required 77 MD5 c261e8a266810189ab2c444e93e8624f RMD160 4b141917b369e14c46b9662539c8a21b5fd02579 SHA1 22f46430bfeed22a19074ccf899d969fdef49710 SHA256 e9f5a1fc29b38d789dbabf133ae87b4e06c3d8095aa2a911ae848e60a79c9ddf SHA512 1e30c4b29c0556555ec17d312c5d06d9caa17a43de89565a893713f4135cb50e14ba4eb0500bb1f9ca0e030b9c0af121e2d28652d6c8ea590f63f48ca3c8e850
-SLACKBUILD puppet.SlackBuild 6752 MD5 2e3b5a06df2db3935cfd96e9618b35bd RMD160 9449a328f970a30a436a9f96a11b8face1807bc8 SHA1 483c62ca43e29ee580360e9a6c726fb458cd8bea SHA256 23e4a8e5d9d824ea69de56469d3029aa064e0856d2d184079a8e76e3e3ca7ae6 SHA512 14919155761a4ce5c5e0aa7cc5e3495ca0b23de927f4236312dbd81f6de75cb39853921f230a7aba9c9b80cff6dc372951d627838e92cbf5211a8ea4f7d7508a
+MISC rc.puppet.new 608 MD5 060bad75020e4145e0b51210b91eb53f RMD160 7a7a4a44daf083493a40b52380d33056283bbed1 SHA1 7d8a1b4a13839c44f4fd6439c1c54ee14f46082c SHA256 b3320132edf2a0fbebe93348e955759c2f43933dadd51af342abdd15282c696c SHA512 28f084fbe810c598ca15e0ce7f595ef9484db4df0c0011b7e88eba0e78de3b2167bb3fdd2e1d2805933e6b9e5ff4d9478cf9c4aa8d2003f421dbfc44874a5c6b
+MISC rc.puppetmaster.new 692 MD5 d25010e67952ea9f9f8c341c8464921b RMD160 f76450346aa9e2614caace9982a4a88b24c30ff4 SHA1 35f3841229b3e4ce20f1c12e43ffa03e32cd006f SHA256 4a013d918601a5812d722bf4cab1b1aaf5e116ae30bed7e72e71ec221907650a SHA512 f602611962d42410b9b06169cdf8e7a8e8e292dd62e5a44793025323566446b5976ea39d6fe26e2f7b675b25aa6aaadd426bddb08c2f4afc9897966e98f9f13c
+MKBUILD puppet.mkbuild 5282 MD5 8006bcbc0abbf29d59f1b6296371d3f0 RMD160 2f93d8e71756e41d5e194afd24ff2281aa3ab94c SHA1 43a315841c7ee139702fdf9b09c34b19aa13156c SHA256 5ea76ffe630b3a441cb3f2096826609927ae62613bc59a2995ca60579c66b70f SHA512 46522d5dc97f0e472de38b66b9826dd310c4024d558c1c91ffdc80978dcb4f37ac5ed2993d5c3b539df12f065fdb927a1ce9c5366daf973c2bd1725d796952bb
+SLACK-REQUIRED slack-required 88 MD5 2037e0312db77ea7af8eb36c2924497b RMD160 21ed35e57720877744b3af57274fb3735e5fea6b SHA1 ed5f326178af5e3cb6e0c6e3f29e5dbe0c1d6538 SHA256 815fd9b9250c3b44ee5eafe02db47ccc5222cf6cc08db0e2fc3a00371484b2cb SHA512 2e2a433f8ecb778c0092672082b9a44d43d5a99e2ac61e82d3c7cb184758365119b097461699d75a512fe4a67d11e4bca9e3b10b4e3c683dbd92b43717ac3dce
+SLACKBUILD puppet.SlackBuild 7997 MD5 bc0031178c8880a352726942d0c3d13e RMD160 95e2ad8494123425eb8a789621e5fd31b2a1d3d5 SHA1 00b44a9df3ebbd8217cf30c7e66e34f02ad089a5 SHA256 9db8850710ce895b74254460694fda026eb3e57c0de60bbae85480c8a3e56a3e SHA512 c8912526963199f9de29ece17af6610ce55b6b90ff9e27c71c846c3d96df0ef7d6b02261d7de725ac9a18660e40cac59e882bc0c7fa0d1cd5ef84bb72a797083
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.9 (GNU/Linux)
-iQIcBAEBCAAGBQJKR8lHAAoJEEHL93ESzgeiPmIP/2xV+d7NKhlE+zfVmp5Jz+O8
-RRWdqnQqo0gtq7EGCQA5w8srzn1Y8LYu1f7bZeL2OM4Gq1v0RAzZHF5OihX1D9tO
-q3XuIsVwsOUqXsq+9v3uR4WIPc5mk+WTx15UkXvc8rLj+dsO/OSBljzYDY+W7loh
-ALOMLII+Hy1TWvsZEBv+/j3A+/6WSQ0SbJLEpkmU9dSfVQpkUMD24RWa0vcAeq4g
-u/UavIQ6n7/Il9ct3q3zvsJP94M/VV3gKe20dLGJxQLCZJ0tJxhfU7zePPsBi6DV
-fuEh58a9PgjyDvFfeEPUFs+WZ9GV26Sz623HjGUftrVdojrh40lLVw3uvVu1kELf
-7x/UtGE7U/RHyy7/X4gMD6MPNH5Ss3VQ7UJ1QVFQi6+9hzELV4sZEMl42LBeZtc6
-Ue+2Ezpn4QI4+08FIZc3XixZb9sugIf8dpLFxyZfJKBnUIufwjRVkGPfIzy/bWCT
-czWET+4KxQFSNFst6NfH7HZce8Scmdi8uVqEKdEkv6LRSW2o4awxqCKoviQ30T+1
-+K7sjXQzTDj+PymWoSngMUKMyVEiiX1Bq9BTy8/4sDpIS112a9Zj3WZxAGZ3lZB1
-1Q5rxhrtP4JHOFfEdkKx31bcLwyhudDzhjAUkxaAKiw9d0Kxd81rzERAboAOIely
-B3r+9QIg+Jvo0wW0/Rx5
-=/CLO
+iQIcBAEBCAAGBQJKSAWqAAoJEEHL93ESzgeian4P/1FKFidrU4NDVyoBOkqwEg89
+2MUo97Uw8CTrCeUdGsbpH6wnIhEFOdisniv5t2R8wg9pX62U9Nlcsxft/e5l5IXg
+Er52J9ljZlwICxSq/wscvmTBCtaVHjCeZUEq+oj90g+UaWIGhFeZ62GPFE6p/LGg
+GiZeeZmo9JyzbRARcIwCukUSch+XoGv6OYqqE8FZ751bLy6TzZmbsJklT9kezoZ3
+YZMKURWERyM16QCH8/ov9Zh8xAuXvYsYZZHGYPbEDqDJSS7UJQojuh+HvGzpF1l5
+V0aq6AhSHaFOyIM3u64T3/VLM36gPyNJE7fOM3gVNoGlt8ADAZWexJfY2Ic1aD0O
+/v34J3CsgplI2vIOuTz8mh5ECgdzrkOzHUkqn27LNnMos1HgEu1o/eVg90Pbj81x
+KnY5H1e11JPVjNofLjqZ/mjn7e7BulPtLnyYC9WnRahZg/et49eoCML6+GvMpSEw
+WerM48yciaG8YaHol1sYa0NNKEys0OXEebJ9dnky47zGpR0rDMXaUiK8lJWZrbTy
+rxLQLt0KFQ1W+1nTMZBcGVcHnFfsUYZgkAM+WKgxFdYLiwHspJuogvl8jZcrrE54
+N2OqXddTOQZPQ4IsbrbM/ItRuNpg2c4O/QvMEyvjUmbiNWVOKdROX6MlkdJHrZdO
+b3ofGF74qqAmMnSLjmOR
+=AwPv
-----END PGP SIGNATURE-----
diff --git a/app/admin/puppet/puppet.SlackBuild b/app/admin/puppet/puppet.SlackBuild
index 85de6dc9..aa4ef57f 100644
--- a/app/admin/puppet/puppet.SlackBuild
+++ b/app/admin/puppet/puppet.SlackBuild
@@ -15,7 +15,7 @@
# 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
#
# slackbuild for puppet, by Silvio Rhatto
-# requires: facter
+# requires: facter openrc
# tested: puppet-0.24.8
# model: generic.mkSlackBuild $Rev: 805 $
#
@@ -34,7 +34,7 @@ PKG_NAME="puppet"
ARCH=${ARCH:=i486}
SRC_VERSION=${VERSION:=0.24.8}
PKG_VERSION="$(echo "$SRC_VERSION" | tr '[[:blank:]-]' '_')"
-BUILD=${BUILD:=1rha}
+BUILD=${BUILD:=2rha}
SRC_DIR=${SRC_DIR:=$CWD}/$PKG_NAME
TMP=${TMP:=/tmp}
PKG=${PKG:=$TMP/package-$PKG_NAME}
@@ -161,6 +161,7 @@ cd "$PKG_SRC"
# Build and install package
ruby install.rb --destdir=$PKG || exit $ERROR_INSTALL
+mkdir -p /var/run/puppet /etc/puppet
# Strip binaries
( cd "$PKG"
@@ -170,6 +171,10 @@ ruby install.rb --destdir=$PKG || exit $ERROR_INSTALL
xargs strip --strip-unneeded 2> /dev/null
)
+# Copy init scripts
+mkdir -p $PKG/etc/rc.d
+cp $CWD/rc.* $PKG/etc/rc.d/
+
# Install documentation
DOCS="CHANGELOG COPYING LICENSE README README.rst Rakefile"
mkdir -p "$PKG/usr/doc/$PKG_NAME-$PKG_VERSION" || exit $ERROR_MKDIR
@@ -203,6 +208,49 @@ puppet:
puppet:
EODESC
+# Add a post-installation script (doinst.sh)
+mkdir -p "$PKG/install" || exit $ERROR_MKDIR
+cat << EOSCRIPT > "$PKG/install/doinst.sh"
+config() {
+ NEW="\$1"
+ OLD="\$(dirname \$NEW)/\$(basename \$NEW .new)"
+ OLD="\$(dirname \$NEW)/\$(basename \$OLD .sample)"
+ OLD="\$(dirname \$NEW)/\$(basename \$OLD .dist)"
+
+ # If there's no config file by that name, mv it over:
+ if [ ! -r \$OLD ]; then
+ mv \$NEW \$OLD
+ elif [ "\$(cat \$OLD | md5sum)" = "\$(cat \$NEW | md5sum)" ]; then
+ # toss the redundant copy
+ rm \$NEW
+ fi
+ # Otherwise, we leave the .new copy for the admin to consider...
+}
+
+mkgroup() {
+ GROUP="\$1"
+ if ! grep -qe "^\$GROUP:" etc/group; then
+ echo Creating group \$GROUP...
+ chroot . /usr/sbin/groupadd \$GROUP
+ fi
+}
+
+mkuser() {
+ USER="\$1"
+ if [ ! -z "\$2" ]; then
+ GROUP="\$2"
+ else
+ GROUP="\$USER"
+ fi
+ if ! grep -qe "^\$USER:" etc/passwd; then
+ echo Creating user \$USER...
+ chroot . /usr/sbin/useradd \$USER -g \$GROUP
+ fi
+}
+
+config etc/rc.d/rc.puppet.new ; config etc/rc.d/rc.puppetmaster.new; mkgroup puppet; mkuser puppet; chown puppet.puppet /var/run/puppet
+EOSCRIPT
+
# Build the package
cd "$PKG"
mkdir -p $REPOS/$SLACKBUILD_PATH
diff --git a/app/admin/puppet/rc.puppet.new b/app/admin/puppet/rc.puppet.new
new file mode 100644
index 00000000..d9738c0d
--- /dev/null
+++ b/app/admin/puppet/rc.puppet.new
@@ -0,0 +1,36 @@
+#!/bin/sh
+
+puppet_start() {
+ echo "Starting puppet"
+ start-stop-daemon --start --quiet \
+ --pidfile "/var/run/puppetd.pid" \
+ --exec /usr/bin/puppetd
+ if [ "$?" != "0" ]; then
+ echo "Failed to start puppet"
+ fi
+}
+
+puppet_stop() {
+ echo "Stopping puppet"
+ start-stop-daemon --stop --quiet \
+ --pidfile "/var/run/puppet/puppetd.pid"
+ if [ "$?" != "0" ]; then
+ echo "Failed to stop puppet"
+ fi
+ rm -f "/var/run/puppet/puppetd.pid"
+}
+
+case "$1" in
+'start')
+ puppet_start
+ ;;
+'stop')
+ puppet_stop
+ ;;
+'restart')
+ puppet_stop
+ puppet_start
+ ;;
+*)
+ echo "usage $0 start|stop|restart"
+esac
diff --git a/app/admin/puppet/rc.puppetmaster.new b/app/admin/puppet/rc.puppetmaster.new
new file mode 100644
index 00000000..1217fbc6
--- /dev/null
+++ b/app/admin/puppet/rc.puppetmaster.new
@@ -0,0 +1,36 @@
+#!/bin/sh
+
+puppetmaster_start() {
+ echo "Starting puppetmaster"
+ start-stop-daemon --start --quiet \
+ --pidfile "/var/run/puppetmasterd.pid" \
+ --exec /usr/bin/puppetmasterd
+ if [ "$?" != "0" ]; then
+ echo "Failed to start puppetmaster"
+ fi
+}
+
+puppetmaster_stop() {
+ echo "Stopping puppetmaster"
+ start-stop-daemon --stop --quiet \
+ --pidfile "/var/run/puppet/puppetmasterd.pid"
+ if [ "$?" != "0" ]; then
+ echo "Failed to stop puppetmaster"
+ fi
+ rm -f "/var/run/puppet/puppetmasterd.pid"
+}
+
+case "$1" in
+'start')
+ puppetmaster_start
+ ;;
+'stop')
+ puppetmaster_stop
+ ;;
+'restart')
+ puppetmaster_stop
+ puppetmaster_start
+ ;;
+*)
+ echo "usage $0 start|stop|restart"
+esac
diff --git a/app/admin/puppet/slack-required b/app/admin/puppet/slack-required
index c8ca4a44..eba2d803 100644
--- a/app/admin/puppet/slack-required
+++ b/app/admin/puppet/slack-required
@@ -2,3 +2,4 @@
#
# dependency [condition] [version]]
facter
+openrc
diff --git a/sys/apps/openrc/Manifest b/sys/apps/openrc/Manifest
new file mode 100644
index 00000000..b82adf1e
--- /dev/null
+++ b/sys/apps/openrc/Manifest
@@ -0,0 +1,24 @@
+-----BEGIN PGP SIGNED MESSAGE-----
+Hash: SHA256
+
+DIST openrc-0.5.0.tar.bz2 150907 MD5 9ec7f8425e12abbbd0f7a962aae3fa3c RMD160 149b793aeecb174005da1d9e43f997dbdc63c5bd SHA1 2142d0e9d3db5941bf58d411b7d996532a333139 SHA256 168a19c38572e8f822137676eeae6233b507c8b8efcf19421cdc8675fc22e4c1 SHA512 dabecf7d644dac6e9f527699af308e2d099a5c96e0dc55406cac1b9054a0bd2c6ad99b23779cb775efb3f1c085a9878726596f8f360ebcaab3b66dab52489e28
+MKBUILD openrc.mkbuild 5192 MD5 e77be64c425fdd3dc9587bb97b4701a3 RMD160 b4d2665f02c71542429b497599f69f48183c0262 SHA1 f3f3fe115fc95f43d13f4740f101d06737382ad4 SHA256 5e6526459c9082012a1a233663b0a08c0262b90fc06124db84c184419b4f1deb SHA512 42ed5d879a49b7f945688bda010c25dad160c610fcf153325020f69f8aca208ff7b134af4765c1e5840875d6d4d7b1917cfc3b009067ab5d86e54a46090b84bc
+PATCH openrc-0.5.0.diff 1526 MD5 195fb9dc90e5ffc046c98f4ab6cffbcf RMD160 0a3840da6d69036d21421003da4220d84bdf73d3 SHA1 1ce4b0d60659e9d6f01cc576fde029be6c9d9e48 SHA256 91733ce86baed0621b571ecfbc3435009fee3d907373ae77c9377febd37f73d8 SHA512 7c5b8dae16af9693f8c1a59ad9c712272704d8745211f0aadf0860465aae12f3bcf1d6b96de91a5f0e055b4148acd01425d8f2a3f95da4fb812bdef094cfa6e9
+SLACKBUILD openrc.SlackBuild 8338 MD5 f716c68534885049c9e1a531971ce4c7 RMD160 87e0610db4f909b255a6d4c0e041932858f01558 SHA1 7da15a3a83e30a8626c95fbdb958f39ed6f50d2d SHA256 8652f9a177733f3fed23e61d07add6851866fc22b2c67dc5a33cf017b0921781 SHA512 01cedae92d83f93d8464c026a8e64474914fe4ea056899d55e7d5318abfa766d7b5003fafc2cf33ff0577be2b83aa7437786c0a4c61c51a1408901c022ab9721
+-----BEGIN PGP SIGNATURE-----
+Version: GnuPG v1.4.9 (GNU/Linux)
+
+iQIcBAEBCAAGBQJKR/tSAAoJEEHL93ESzgeiQg4QAI02v2wf1zJwwAt+sDD4B4kg
+/tx4uC6ZF3aDJXcSQHQI6NgZ5l8KvE5AyrFWcIaCEy6f0xaNQ+iop6O3FYwFtDXY
+Ikqmkf0r9QzKsDWRdW5GObsGBEfrVc6YcvFaiixohJmMlbqZnlyDOgNixhm9+m1W
+Jqf3VwnJVtoPQD5xsVFErmrRxfE0aVXkOaQqESCMkNhCodrek0mgyj8ahE5TNuXn
+Db2hC2BPC7bkteoFjKWFOd466gGILnefyj0TS5V9pQ6r7Aod7Yuds+6u9CWQ2Myz
+vS9f/k+iSYPDIytWOXjriuwaGMT3FZzMppNdiBQoii3Ce/itFi9YDcWFJcxLJ0bx
+l70amOs5KtwRP4m0K/soCyQ43SbKTMRurngbPXtQpHTF0jiGbQfXFAXCZn1NujMP
+8mvMRlWQzO4YowJDqH/T4Uif9hQ4z/QyC5EPrTCMexe2rWmBeHin3cAZlnDlGOLh
+Ob8zwmpXioY3IbpdrcByig8T1JCw9Y4zMz80PpbGM7C/1dWtthV0u1dQqXMZjeBf
+Qt3hqqWEKHoMtx9cRFEdP63Ky2iaPtqu2u6ukNJYrpmeS5u23M6kOi98Gtt6ccMg
+1IZWsampLbFDEL5qhgFsSkiv8TOfzHFW3fWZ8uhNFM2/085m08YnpCCePRdaSV/Z
+9rL5qWVuI/TRk0OXdI0A
+=Fq61
+-----END PGP SIGNATURE-----
diff --git a/sys/apps/openrc/openrc-0.5.0.diff b/sys/apps/openrc/openrc-0.5.0.diff
new file mode 100644
index 00000000..167c671c
--- /dev/null
+++ b/sys/apps/openrc/openrc-0.5.0.diff
@@ -0,0 +1,27 @@
+diff -Naur openrc-0.5.0.orig/LICENSE openrc-0.5.0/LICENSE
+--- openrc-0.5.0.orig/LICENSE 1969-12-31 21:00:00.000000000 -0300
++++ openrc-0.5.0/LICENSE 2009-06-28 20:11:00.000000000 -0300
+@@ -0,0 +1,23 @@
++Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
++All rights reserved
++
++Redistribution and use in source and binary forms, with or without
++modification, are permitted provided that the following conditions
++are met:
++1. Redistributions of source code must retain the above copyright
++ notice, this list of conditions and the following disclaimer.
++2. Redistributions in binary form must reproduce the above copyright
++ notice, this list of conditions and the following disclaimer in the
++ documentation and/or other materials provided with the distribution.
++
++THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
++ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
++IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
++ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
++FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
++DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
++OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
++HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
++LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
++OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
++SUCH DAMAGE.
diff --git a/sys/apps/openrc/openrc.SlackBuild b/sys/apps/openrc/openrc.SlackBuild
new file mode 100644
index 00000000..40f5222d
--- /dev/null
+++ b/sys/apps/openrc/openrc.SlackBuild
@@ -0,0 +1,257 @@
+#!/bin/bash
+#
+# openrc.SlackBuild 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 any later version.
+#
+# openrc.SlackBuild 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.,
+# 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
+#
+# slackbuild for openrc, by Silvio Rhatto
+# requires:
+# tested: openrc-0.5.0
+# model: generic.mkSlackBuild $Rev: 805 $
+#
+
+# Look for slackbuildrc
+if [ -f ~/.slackbuildrc ]; then
+ source ~/.slackbuildrc
+elif [ -f /etc/slackbuildrc ]; then
+ source /etc/slackbuildrc
+fi
+
+# Set variables
+CWD="$(pwd)"
+SRC_NAME="openrc"
+PKG_NAME="openrc"
+ARCH=${ARCH:=i486}
+SRC_VERSION=${VERSION:=0.5.0}
+PKG_VERSION="$(echo "$SRC_VERSION" | tr '[[:blank:]-]' '_')"
+BUILD=${BUILD:=1rha}
+SRC_DIR=${SRC_DIR:=$CWD}/$PKG_NAME
+TMP=${TMP:=/tmp}
+PKG=${PKG:=$TMP/package-$PKG_NAME}
+REPOS=${REPOS:=$TMP}
+SLACKBUILD_PATH=${SLACKBUILD_PATH:="sys/apps/openrc"}
+PREFIX=${PREFIX:=/usr}
+PKG_WORK="$TMP/$SRC_NAME"
+CONF_OPTIONS=${CONF_OPTIONS:=""}
+NUMJOBS=${NUMJOBS:=""}
+
+# Set system libraries' path and optmization flags based on $ARCH
+LIBDIR="$PREFIX/lib"
+
+if [ "$ARCH" = "i386" ]; then
+ SLKCFLAGS="-O2 -march=i386 -mtune=i686"
+elif [ "$ARCH" = "i486" ]; then
+ SLKCFLAGS="-O2 -march=i486 -mtune=i686"
+elif [ "$ARCH" = "i686" ]; then
+ SLKCFLAGS="-O2 -march=i686"
+elif [ "$ARCH" = "s390" ]; then
+ SLKCFLAGS="-O2"
+elif [ "$ARCH" = "x86_64" ]; then
+ SLKCFLAGS="-O2 -fPIC"
+ LIBDIR="$PREFIX/lib64"
+ LDFLAGS="-L/lib64 -L/usr/lib64"
+fi
+
+# Set error codes (used by createpkg)
+ERROR_WGET=31; ERROR_MAKE=32; ERROR_INSTALL=33
+ERROR_MD5=34; ERROR_CONF=35; ERROR_HELP=36
+ERROR_TAR=37; ERROR_MKPKG=38; ERROR_GPG=39
+ERROR_PATCH=40; ERROR_VCS=41; ERROR_MKDIR=42
+ERROR_MANIFEST=43;
+
+# Clean up any leftovers of previous builds
+rm -rf "$PKG_WORK" 2> /dev/null
+rm -rf "$PKG" 2> /dev/null
+
+# Create directories if necessary
+mkdir -p "$SRC_DIR" || exit $ERROR_MKDIR
+mkdir -p "$PKG" || exit $ERROR_MKDIR
+mkdir -p "$REPOS" || exit $ERROR_MKDIR
+mkdir -p "$PKG_WORK" || exit $ERROR_MKDIR
+
+# Dowload source if necessary
+SRC="$SRC_NAME-$VERSION.tar.bz2"
+URL="http://roy.marples.name/downloads/openrc/$SRC"
+
+if [ ! -s "$SRC_DIR/$SRC" ] || ! bunzip2 -t "$SRC_DIR/$SRC" 2> /dev/null; then
+ wget "$URL" -O "$SRC_DIR/$SRC" || exit $ERROR_WGET
+fi
+
+# Check Manifest file
+if [ -e "$CWD/Manifest" ]; then
+
+ # Manifest signature checking
+ if grep -q -- "-----BEGIN PGP SIGNED MESSAGE-----" $CWD/Manifest; then
+ echo "Checking Manifest signature..."
+ gpg --verify $CWD/Manifest
+ if [ "$?" != "0" ]; then
+ exit $ERROR_MANIFEST
+ fi
+ fi
+
+ MANIFEST_LINES="`grep -E -v "^(MKBUILD|SLACKBUILD)" $CWD/Manifest | wc -l`"
+
+ for ((MANIFEST_COUNT=1; MANIFEST_COUNT <= $MANIFEST_LINES; MANIFEST_COUNT++)); do
+
+ MANIFEST_LINE="`grep -E -v "^(MKBUILD|SLACKBUILD)" $CWD/Manifest | head -n $MANIFEST_COUNT | tail -n 1`"
+ MANIFEST_FILE="`echo $MANIFEST_LINE | awk '{ print $2 }'`"
+ MANIFEST_FILE_TYPE="`echo $MANIFEST_LINE | awk '{ print $1 }'`"
+
+ if [ -e "$SRC_DIR/$MANIFEST_FILE" ]; then
+ MANIFEST_FILE="$SRC_DIR/$MANIFEST_FILE"
+ else
+ MANIFEST_FILE="`find $CWD -name $MANIFEST_FILE`"
+ fi
+
+ if [ ! -e "$MANIFEST_FILE" ] || [ -d "$MANIFEST_FILE" ]; then
+ continue
+ fi
+
+ echo "Checking Manifest for $MANIFEST_FILE_TYPE $MANIFEST_FILE integrity..."
+
+ SIZE_SRC="`wc -c $MANIFEST_FILE | awk '{ print $1 }'`"
+ SIZE_MANIFEST="`echo $MANIFEST_LINE | awk '{ print $3 }'`"
+
+ # Check source code size
+ if [ "$SIZE_SRC" != "$SIZE_MANIFEST" ]; then
+ echo "SIZE Manifest: $SIZE_MANIFEST; SIZE $SRC: $SIZE_SRC"
+ exit $ERROR_MANIFEST
+ else
+ echo "Size match."
+ fi
+
+ # Check source code integrity
+ for ALGO in md5 rmd160 sha1 sha256 sha512; do
+ if [ $ALGO = "rmd160" ]; then
+ ALGO_SRC="`openssl rmd160 $MANIFEST_FILE | awk '{ print $2 }'`"
+ else
+ ALGO_SRC="`"$ALGO"sum $MANIFEST_FILE | awk '{ print $1 }'`"
+ fi
+ ALGO="`echo $ALGO | tr '[:lower:]' '[:upper:]'`"
+ ALGO_MANIFEST=$(echo $MANIFEST_LINE | sed "s/.* $ALGO //" | awk '{ print $1 }')
+ if [ "$ALGO_SRC" != "$ALGO_MANIFEST" ]; then
+ echo "$ALGO Manifest: $ALGO_MANIFEST; $ALGO $SRC: $ALGO_SRC"
+ exit $ERROR_MANIFEST
+ else
+ echo "$ALGO match."
+ fi
+ done
+
+ done
+
+else
+ exit $ERROR_MANIFEST
+fi
+
+# Untar
+cd "$PKG_WORK"
+tar --no-same-owner --no-same-permissions -xvf "$SRC_DIR/$SRC" || exit $ERROR_TAR
+PKG_SRC="$PWD/`ls -l | awk '/^d/ { print $NF }'`"
+cd "$PKG_SRC"
+
+# Patch source
+patches=" [[PATCH URLS]]
+ $PKG_NAME.diff $PKG_NAME-$PKG_VERSION.diff
+ $PKG_NAME-$PKG_VERSION-$ARCH.diff $PKG_NAME-$ARCH.diff"
+for patch in $patches; do
+ patch="`basename $patch`"
+ if [ -f "$CWD/$patch" ]; then
+ patch -Np1 < "$CWD/$patch" || exit $ERROR_PATCH
+ elif [ -f "$CWD/patches/$patch" ]; then
+ patch -Np1 < "$CWD/patches/$patch" || exit $ERROR_PATCH
+ elif [ -f "$CWD/$patch.gz" ]; then
+ gzip -dc "$CWD/$patch.gz" | patch -Np1 || exit $ERROR_PATCH
+ elif [ -f "$CWD/patches/$patch.gz" ]; then
+ gzip -dc "$CWD/patches/$patch.gz" | patch -Np1 || exit $ERROR_PATCH
+ elif [ -f "$SRC_DIR/$patch" ]; then
+ if [ "`basename $patch .gz`" != "$patch" ]; then
+ gzip -dc $SRC_DIR/$patch | patch -Np1 || exit $ERROR_PATCH
+ elif [ "`basename $patch .bz2`" != "$patch" ]; then
+ bzip2 -dc $SRC_DIR/$patch | patch -Np1 || exit $ERROR_PATCH
+ else
+ patch -Np1 < "$SRC_DIR/$patch" || exit $ERROR_PATCH
+ fi
+ fi
+done
+
+# Compile
+make $NUMJOBS || exit $ERROR_MAKE
+
+# Install
+make install DESTDIR="$PKG" || exit $ERROR_INSTALL
+
+# Strip binaries
+( cd "$PKG"
+ find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | \
+ xargs strip --strip-unneeded 2> /dev/null
+ find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | \
+ xargs strip --strip-unneeded 2> /dev/null
+)
+
+# Compress and link manpages
+if [ -d "$PKG/$PREFIX/man" ]; then
+ ( cd "$PKG/$PREFIX/man"
+ for manpagedir in $(find . -type d -name "man*") ; do
+ ( cd $manpagedir
+ for eachpage in $( find . -type l -maxdepth 1) ; do
+ ln -s $( readlink $eachpage ).gz $eachpage.gz
+ rm $eachpage
+ done
+ gzip -9 *.?
+ )
+ done
+ )
+fi
+
+# Install documentation
+DOCS="README TODO"
+mkdir -p "$PKG/usr/doc/$PKG_NAME-$PKG_VERSION" || exit $ERROR_MKDIR
+for doc in $DOCS; do
+ if [ -f "$doc" ]; then
+ cp -a $doc "$PKG/usr/doc/$PKG_NAME-$PKG_VERSION"
+ fi
+done
+
+# Add package description (slack-desc)
+mkdir -p "$PKG/install" || exit $ERROR_MKDIR
+cat << EODESC > "$PKG/install/slack-desc"
+# HOW TO EDIT THIS FILE:
+# The "handy ruler" below makes it easier to edit a package description. Line
+# up the first '|' above the ':' following the base package name, and the '|'
+# on the right side marks the last column you can put a character in. You must
+# make exactly 11 lines for the formatting to be correct. It's also
+# customary to leave one space after the ':'.
+
+ |-----handy-ruler-------------------------------------------------------|
+openrc: openrc
+openrc:
+openrc: OpenRC is a dependency based init system that works with
+openrc: the system provided init program, normally /sbin/init.
+openrc: It is not a replacement for /sbin/init. OpenRC is 100%
+openrc: compatible with Gentoo init scripts, which means you
+openrc: can probably find one for the daemons you want to start
+openrc: in the Gentoo Portage Tree. OpenRC also provides an init
+openrc: script that runs BSD rc.d style scripts too, making it
+openrc: easy to port your BSD system to OpenRC.
+openrc:
+EODESC
+
+# Build the package
+cd "$PKG"
+mkdir -p $REPOS/$SLACKBUILD_PATH
+makepkg -l y -c n "$REPOS/$SLACKBUILD_PATH/$PKG_NAME-$PKG_VERSION-$ARCH-$BUILD.tgz" || exit $ERROR_MKPKG
+
+# Delete source and build directories if requested
+if [ "$CLEANUP" == "yes" ] || [ "$1" = "--cleanup" ]; then
+ rm -rf "$PKG_WORK" "$PKG"
+fi