diff options
Diffstat (limited to 'network/openntpd')
-rw-r--r-- | network/openntpd/README | 13 | ||||
-rw-r--r-- | network/openntpd/doinst.sh | 26 | ||||
-rw-r--r-- | network/openntpd/openntpd.SlackBuild | 142 | ||||
-rw-r--r-- | network/openntpd/openntpd.info | 10 | ||||
-rw-r--r-- | network/openntpd/patches/01-ntpctl_rename.diff | 41 | ||||
-rw-r--r-- | network/openntpd/patches/02-ntpd_8_clean.diff | 39 | ||||
-rw-r--r-- | network/openntpd/patches/02-ntpd_conf_5_clean.diff | 18 | ||||
-rw-r--r-- | network/openntpd/rc.openntpd | 43 | ||||
-rw-r--r-- | network/openntpd/slack-desc | 19 |
9 files changed, 351 insertions, 0 deletions
diff --git a/network/openntpd/README b/network/openntpd/README new file mode 100644 index 0000000000..9f0051a26e --- /dev/null +++ b/network/openntpd/README @@ -0,0 +1,13 @@ +OpenNTPD is a FREE, easy to use implementation of the Network Time Protocol. It +provides the ability to sync the local clock to remote NTP servers and can act +as NTP server itself, redistributing the local clock. + +OpenNTPD was primarily developed by Henning Brauer as part of the OpenBSD +Project and gets released as a base component of OpenBSD every six months. + +The portable version is maintained by Brent Cook and is mirrored on Github and +available as periodic tarball releases. Contributions are welcome to both the +OpenNTPD core and the portable build framework. + +This build script will try to create the user and group '_ntp', that is +necessary to run openntpd. diff --git a/network/openntpd/doinst.sh b/network/openntpd/doinst.sh new file mode 100644 index 0000000000..e13c41ffe1 --- /dev/null +++ b/network/openntpd/doinst.sh @@ -0,0 +1,26 @@ +config() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + # 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... +} + +preserve_perms() { + NEW="$1" + OLD="$(dirname ${NEW})/$(basename ${NEW} .new)" + if [ -e ${OLD} ]; then + cp -a ${OLD} ${NEW}.incoming + cat ${NEW} > ${NEW}.incoming + mv ${NEW}.incoming ${NEW} + fi + config ${NEW} +} + +preserve_perms etc/rc.d/rc.openntpd.new +config etc/openntpd.conf.new diff --git a/network/openntpd/openntpd.SlackBuild b/network/openntpd/openntpd.SlackBuild new file mode 100644 index 0000000000..299f4120f0 --- /dev/null +++ b/network/openntpd/openntpd.SlackBuild @@ -0,0 +1,142 @@ +#!/bin/sh + +# Slackware build script for openntpd + +# Copyright (c) 2015 LEVAI Daniel +# All rights reserved. +# +# * Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions +# are met: +# * Redistributions of source code must retain the above copyright notice +# this list of conditions and the following disclaimer. +# * 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 ''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 +# COPYRIGHT HOLDER 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. + +PRGNAM=openntpd +VERSION=${VERSION:-5.7p1} +BUILD=${BUILD:-1} +TAG=${TAG:-_SBo} + +if [ -z "$ARCH" ]; then + case "$( uname -m )" in + i?86) ARCH=i486 ;; + arm*) ARCH=arm ;; + *) ARCH=$( uname -m ) ;; + esac +fi + +CWD=$(pwd) +TMP=${TMP:-/tmp/SBo} +PKG=$TMP/package-$PRGNAM +OUTPUT=${OUTPUT:-/tmp} + +if [ "$ARCH" = "i486" ]; then + SLKCFLAGS="-O2 -march=i486 -mtune=i686" + LIBDIRSUFFIX="" +elif [ "$ARCH" = "i686" ]; then + SLKCFLAGS="-O2 -march=i686 -mtune=i686" + LIBDIRSUFFIX="" +elif [ "$ARCH" = "x86_64" ]; then + SLKCFLAGS="-O2 -fPIC" + LIBDIRSUFFIX="64" +else + SLKCFLAGS="-O2" + LIBDIRSUFFIX="" +fi + +set -e + +echo "You must have a user and group called '_ntp' to use this package. E.g.: +# groupadd -g 217 _ntp +# useradd -u 217 -m -d /var/empty/openntpd -s /bin/false -g _ntp _ntp" + +# Check the user/group if they're present +egrep -q -e '^_ntp:' /etc/passwd +egrep -q -e '^_ntp:' /etc/group + +# Create the _ntp user's home, and the daemon's chroot directory +mkdir -p $PKG/var/empty/openntpd +chown root:root $PKG/var/empty/openntpd +chmod 0755 $PKG/var/empty/openntpd + +rm -rf $PKG +mkdir -p $TMP $PKG $OUTPUT +cd $TMP +rm -rf $PRGNAM-$VERSION +tar xvf $CWD/$PRGNAM-$VERSION.tar.gz +cd $PRGNAM-$VERSION +chown -R root:root . +find -L . \ + \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \ + -o -perm 511 \) -exec chmod 755 {} \; -o \ + \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \ + -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \; + +for diff in $CWD/patches/*.diff;do + patch -p1 < "${diff}" +done + +# Prepare the source for renamings, later in the build script +sed -i -r -e 's,^(#define CONFFILE SYSCONFDIR "/)(ntpd)(\.conf")$,\1open\2\3,' ./ntpd.h +sed -i -r -e 's,^(#define DRIFTFILE LOCALSTATEDIR "/db/)(ntpd)(\.drift")$,\1open\2\3,' ./ntpd.h +sed -i -r -e 's,^(#define CTLSOCKET LOCALSTATEDIR "/run/)(ntpd)(\.sock")$,\1open\2\3,' ./ntpd.h +sed -i -r -e 's,ntpd,openntpd,;s,NTPD,OPENNTPD,;s,ntpctl,openntpctl,' \ + ./ntpd.8 ./ntpd.conf.5 ./ntpctl.8 ./ntpd.conf +sed -i -r -e 's,adjfreq,adjtime,' ./ntpd.8 + +CFLAGS="$SLKCFLAGS" \ +./configure \ + --prefix=/usr \ + --libdir=/usr/lib${LIBDIRSUFFIX} \ + --sysconfdir=/etc \ + --localstatedir=/var \ + --mandir=/usr/man \ + --build=$ARCH-slackware-linux + +make +make install DESTDIR=$PKG + +# Remove unnecessary directories created by `make install` +rmdir $PKG/var/run/ + +find $PKG -print0 | xargs -0 file | grep -e "executable" -e "shared object" | grep ELF \ + | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true + +find $PKG/usr/man -type f -exec gzip -9 {} \; +for i in $( find $PKG/usr/man -type l ) ; do ln -s $( readlink $i ).gz $i.gz ; rm $i ; done + +# Don't interfere with stock ntp package +mv $PKG/usr/sbin/ntpd $PKG/usr/sbin/openntpd +mv $PKG/usr/sbin/ntpctl $PKG/usr/sbin/openntpctl +mv $PKG/usr/man/man8/ntpd.8.gz $PKG/usr/man/man8/openntpd.8.gz +mv $PKG/usr/man/man8/ntpctl.8.gz $PKG/usr/man/man8/openntpctl.8.gz +mv $PKG/usr/man/man5/ntpd.conf.5.gz $PKG/usr/man/man5/openntpd.conf.5.gz +mv $PKG/etc/ntpd.conf $PKG/etc/openntpd.conf.new + +# Add an init script +mkdir -p $PKG/etc/rc.d +install -m 0644 $CWD/rc.openntpd $PKG/etc/rc.d/rc.openntpd.new + +mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION +cp -a INSTALL README $PKG/usr/doc/$PRGNAM-$VERSION +cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild + +mkdir -p $PKG/install +cat $CWD/slack-desc > $PKG/install/slack-desc +cat $CWD/doinst.sh > $PKG/install/doinst.sh + +cd $PKG +/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz} diff --git a/network/openntpd/openntpd.info b/network/openntpd/openntpd.info new file mode 100644 index 0000000000..c4782abdb7 --- /dev/null +++ b/network/openntpd/openntpd.info @@ -0,0 +1,10 @@ +PRGNAM="openntpd" +VERSION="5.7p1" +HOMEPAGE="http://www.openntpd.org/portable.html" +DOWNLOAD="http://ftp.OpenBSD.org/pub/OpenBSD/OpenNTPD/openntpd-5.7p1.tar.gz" +MD5SUM="800c5d3ef2b8e3ac403698fdf0c54c2a" +DOWNLOAD_x86_64="" +MD5SUM_x86_64="" +REQUIRES="" +MAINTAINER="LEVAI Daniel" +EMAIL="leva@ecentrum.hu" diff --git a/network/openntpd/patches/01-ntpctl_rename.diff b/network/openntpd/patches/01-ntpctl_rename.diff new file mode 100644 index 0000000000..acf5c7186a --- /dev/null +++ b/network/openntpd/patches/01-ntpctl_rename.diff @@ -0,0 +1,41 @@ +--- a/ntpd.c.orig 2015-01-08 10:43:16.834158734 +0100 ++++ b/ntpd.c 2015-01-08 10:46:24.943458619 +0100 +@@ -100,8 +100,9 @@ usage(void) + { + extern char *__progname; + +- if (strcmp(__progname, "ntpctl") == 0) +- fprintf(stderr, "usage: ntpctl [-s all | peers | Sensors | status]\n"); ++ if (strcmp(__progname, "openntpctl") == 0) ++ fprintf(stderr, "usage: %s [-s all | peers | Sensors | status]\n", ++ __progname); + else + fprintf(stderr, "usage: %s [-dnSsv] [-f file] [-p file]\n", + __progname); +@@ -124,7 +125,7 @@ main(int argc, char *argv[]) + extern char *__progname; + time_t start_time; + +- if (strcmp(__progname, "ntpctl") == 0) { ++ if (strcmp(__progname, "openntpctl") == 0) { + ctl_main (argc, argv); + /* NOTREACHED */ + } +@@ -605,7 +606,7 @@ ctl_main(int argc, char *argv[]) + usage(); + + if ((fd = socket(AF_UNIX, SOCK_STREAM, 0)) == -1) +- err(1, "ntpctl: socket"); ++ err(1, "openntpctl: socket"); + + bzero(&sa, sizeof(sa)); + sa.sun_family = AF_UNIX; +@@ -650,7 +651,7 @@ ctl_main(int argc, char *argv[]) + if ((n = imsg_read(ibuf_ctl)) == -1) + err(1, "ibuf_ctl: imsg_read error"); + if (n == 0) +- errx(1, "ntpctl: pipe closed"); ++ errx(1, "openntpctl: pipe closed"); + + while (!done) { + if ((n = imsg_get(ibuf_ctl, &imsg)) == -1) diff --git a/network/openntpd/patches/02-ntpd_8_clean.diff b/network/openntpd/patches/02-ntpd_8_clean.diff new file mode 100644 index 0000000000..5133f5bc56 --- /dev/null +++ b/network/openntpd/patches/02-ntpd_8_clean.diff @@ -0,0 +1,39 @@ +--- a/ntpd.8.orig 2015-01-08 07:57:55.000000000 +0100 ++++ b/ntpd.8 2015-01-08 11:35:04.889368624 +0100 +@@ -1,7 +1,3 @@ +-.\" $OpenBSD: ntpd.8,v 1.36 2013/10/04 14:28:16 phessler Exp $ +-.\" +-.\" Copyright (c) 2003, 2004, 2006 Henning Brauer <henning@openbsd.org> +-.\" + .\" Permission to use, copy, modify, and distribute this software for any + .\" purpose with or without fee is hereby granted, provided that the above + .\" copyright notice and this permission notice appear in all copies. +@@ -99,19 +95,6 @@ adjusts the clock frequency using the + .Xr adjfreq 2 + system call to compensate for systematic drift. + .Pp +-.Nm +-is usually started at boot time, and can be enabled by +-setting +-.Va ntpd_flags +-in +-.Pa /etc/rc.conf.local . +-See +-.Xr rc 8 +-and +-.Xr rc.conf 8 +-for more information on the boot process +-and enabling daemons. +-.Pp + When + .Nm + starts up, it reads settings from its configuration file, +@@ -144,8 +127,6 @@ Socket file for communication with + .Xr adjtime 2 , + .Xr ntpd.conf 5 , + .Xr ntpctl 8 , +-.Xr rc 8 , +-.Xr rc.conf 8 , + .Xr rdate 8 + .Sh STANDARDS + .Rs diff --git a/network/openntpd/patches/02-ntpd_conf_5_clean.diff b/network/openntpd/patches/02-ntpd_conf_5_clean.diff new file mode 100644 index 0000000000..7a6e7cfdb5 --- /dev/null +++ b/network/openntpd/patches/02-ntpd_conf_5_clean.diff @@ -0,0 +1,18 @@ +--- a/ntpd.conf.5.orig 2015-01-08 11:35:23.671118459 +0100 ++++ b/ntpd.conf.5 2015-01-08 11:36:10.673989819 +0100 +@@ -1,5 +1,3 @@ +-.\" $OpenBSD: ntpd.conf.5,v 1.23 2011/09/21 15:41:30 phessler Exp $ +-.\" + .\" Copyright (c) 2003, 2004 Henning Brauer <henning@openbsd.org> + .\" + .\" Permission to use, copy, modify, and distribute this software for any +@@ -196,9 +194,3 @@ The + .Nm + file format first appeared in + .Ox 3.6 . +-.Sh CAVEATS +-When using different +-.Cm rtable +-options, +-.Xr ntpd 8 +-must be started in rtable 0. diff --git a/network/openntpd/rc.openntpd b/network/openntpd/rc.openntpd new file mode 100644 index 0000000000..52206765cf --- /dev/null +++ b/network/openntpd/rc.openntpd @@ -0,0 +1,43 @@ +#!/bin/sh + +# Start/stop/restart the network time protocol daemon + +# Written for Slackware Linux by Robby Workman <http://rlworkman.net> +# (by modifying one of Pat's scripts) + +# Add -s to the command to set the time at startup + +openntpd_start() { + if [ -x ${BIN} ]; then + echo "Starting openntpd daemon: ${BIN}" + ${BIN} -p /var/run/openntpd.pid + fi +} + +openntpd_stop() { + echo "Stopping openntpd daemon..." + pkill -x $(basename ${BIN}) +} + +openntpd_restart() { + openntpd_stop + sleep 1 + openntpd_start +} + +BIN=/usr/sbin/openntpd + +case "$1" in + 'start') + openntpd_start + ;; + 'stop') + openntpd_stop + ;; + 'restart') + openntpd_restart + ;; + *) + echo "usage $0 start|stop|restart" + ;; +esac diff --git a/network/openntpd/slack-desc b/network/openntpd/slack-desc new file mode 100644 index 0000000000..a9230f2974 --- /dev/null +++ b/network/openntpd/slack-desc @@ -0,0 +1,19 @@ +# 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 ':' except on otherwise blank lines. + + |-----handy-ruler------------------------------------------------------| +openntpd: Openntpd (Network Time Protocol client/server) +openntpd: +openntpd: OpenNTPD is a FREE, easy to use implementation of the Network Time +openntpd: Protocol. It provides the ability to sync the local clock to remote +openntpd: NTP servers and can act as NTP server itself, redistributing the +openntpd: local clock. OpenNTPD is part of the OpenBSD Project, and this is the +openntpd: portable version. +openntpd: +openntpd: Homepage: http://www.openntpd.org/portable +openntpd: +openntpd: |