summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Frysinger <vapier@gentoo.org>2003-08-06 07:42:24 +0000
committerMike Frysinger <vapier@gentoo.org>2003-08-06 07:42:24 +0000
commit2dc0c84f833657e5e0cedb6ae1c6549b1f49c74b (patch)
treec87d9e980188cd6bee2497c3e093d9543247d6ad /net-misc/ntp
parentminor permissions bug fix and move to stable (diff)
downloadhistorical-2dc0c84f833657e5e0cedb6ae1c6549b1f49c74b.tar.gz
historical-2dc0c84f833657e5e0cedb6ae1c6549b1f49c74b.tar.bz2
historical-2dc0c84f833657e5e0cedb6ae1c6549b1f49c74b.zip
version bump + patches #17336 #21017 #21444 #26023
Diffstat (limited to 'net-misc/ntp')
-rw-r--r--net-misc/ntp/ChangeLog9
-rw-r--r--net-misc/ntp/files/4.1.2-droproot.patch476
-rw-r--r--net-misc/ntp/files/broadcastclient.patch12
-rw-r--r--net-misc/ntp/files/digest-ntp-4.1.22
-rw-r--r--net-misc/ntp/files/ntp-client.confd22
-rw-r--r--net-misc/ntp/files/ntp-client.rc31
-rw-r--r--net-misc/ntp/files/ntpd-4.1.1b.confd40
-rw-r--r--net-misc/ntp/files/ntpd-4.1.1b.rc44
-rw-r--r--net-misc/ntp/files/ntpd.confd40
-rw-r--r--net-misc/ntp/files/ntpd.rc11
-rw-r--r--net-misc/ntp/ntp-4.1.1b-r6.ebuild6
-rw-r--r--net-misc/ntp/ntp-4.1.2.ebuild105
12 files changed, 749 insertions, 49 deletions
diff --git a/net-misc/ntp/ChangeLog b/net-misc/ntp/ChangeLog
index 1fef8cc2e917..f335b0bec103 100644
--- a/net-misc/ntp/ChangeLog
+++ b/net-misc/ntp/ChangeLog
@@ -1,7 +1,14 @@
# ChangeLog for net-misc/ntp
# Copyright 2002-2003 Gentoo Technologies, Inc.; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/net-misc/ntp/ChangeLog,v 1.29 2003/06/20 02:40:02 kumba Exp $
+# $Header: /var/cvsroot/gentoo-x86/net-misc/ntp/ChangeLog,v 1.30 2003/08/06 07:42:24 vapier Exp $
+*ntp-4.1.2 (06 Aug 2003)
+
+ 06 Aug 2003; Mike Frysinger <vapier@gentoo.org> :
+ Version bump (omg about time) #26023.
+ Add redhat drop root patch #21444.
+ Add broadcast bug fix #17336.
+ Split ntp init script into server and client scripts #21017.
*ntp-4.1.1b-r6 (16 Jun 2003)
diff --git a/net-misc/ntp/files/4.1.2-droproot.patch b/net-misc/ntp/files/4.1.2-droproot.patch
new file mode 100644
index 000000000000..73cc21afff52
--- /dev/null
+++ b/net-misc/ntp/files/4.1.2-droproot.patch
@@ -0,0 +1,476 @@
+Originally from ftp://ftp.redhat.com/pub/redhat/linux/7.2/en/os/i386/SRPMS/ntp-4.1.0-4.src.rpm
+See <https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=35653> for details.
+--- ntp-4.0.99m-rc2/html/ntpd.htm.droproot Thu May 24 08:04:57 2001
++++ ntp-4.0.99m-rc2/html/ntpd.htm Thu Aug 30 12:29:04 2001
+@@ -22,7 +22,7 @@
+ driftfile</i> ] [ -g ] [ -k <i>keyfile</i> ] [ -l <i>logfile</i> ]
+ [ -N high ] [ -p <i>pidfile</i> ] [ -r <i>broadcastdelay</i> ] [ -s
+ <i>statsdir</i> ] [ -t <i>key</i> ] [ -v <i>variable</i> ] [ -V <i>
+-variable</i> ] [ -x ]</tt>
++variable</i> ] [ -T <i>chroot_dir</i> ] [ -U <i>server_user</i> ] [ -x ]</tt>
+
+ <h4>Description</h4>
+
+@@ -379,6 +379,19 @@
+
+ <dd>Add a system variable listed by default.</dd>
+
++
++<DT><TT>-T <I>chroot_dir</I></TT></DT>
++<DD>Chroot the ntpd server process into <I>chroot_dir</I>. To use this
++option you have to copy all the files that ntpd process needs into the
++chroot directory. This option adds security only if the server also drops
++root privileges (see -U option).</DD>
++
++<DT><TT>-U <I>server_user</I></TT></DT>
++<DD>Ntpd process drops root privileges and changes user ID to
++<I>server_user</I> and group ID to the primary group of <I>server_user</I>.
++To use this option you need libcap-library.
++</DD>
++
+ <dt><tt>-x</tt></dt>
+
+ <dd>Normally, the time is slewed if the offset is less than the
+--- ntp-4.0.99m-rc2/html/ntpdate.htm.droproot Tue Apr 3 05:43:05 2001
++++ ntp-4.0.99m-rc2/html/ntpdate.htm Thu Aug 30 12:29:04 2001
+@@ -26,6 +26,7 @@
+
+ <tt>ntpdate [ -bBdoqsuv ] [ -a <i>key</i> ] [ -e <i>authdelay</i> ]
+ [ -k <i>keyfile</i> ] [ -o <i>version</i> ] [ -p <i>samples</i> ] [
++-U <i>user_name</i> ] [
+ -t <i>timeout</i> ] <i>server</i> [ ... ]</tt>
+
+ <h4>Description</h4>
+@@ -161,6 +162,12 @@
+
+ <dd>Be verbose. This option will cause <tt>ntpdate</tt>'s version
+ identification string to be logged.</dd>
++
++<dt><tt>-U <i>user_name</i></tt></dt>
++
++<dd>ntpdate process drops root privileges and changes user ID to
++<i>user_name</i> and group ID to the primary group of <i>server_user</i>.
++To use this option you need libcap-library.</dd>
+ </dl>
+
+ <h4>Files</h4>
+--- ntp-4.1.2/ntpd/Makefile.am.orig 2003-08-06 02:12:03.000000000 -0400
++++ ntp-4.1.2/ntpd/Makefile.am 2003-08-06 02:12:10.000000000 -0400
+@@ -9,7 +9,7 @@
+ # sqrt ntp_control.o
+ # floor refclock_wwv.o
+ # which are (usually) provided by -lm.
+-ntpd_LDADD = $(LDADD) -lm
++ntpd_LDADD = $(LDADD) -lm -lcap
+ DISTCLEANFILES = .version version.c
+ #EXTRA_DIST = ntpd.mak
+ ETAGS_ARGS = Makefile.am
+--- ntp-4.0.99m-rc2/ntpd/ntpd.c.droproot Sat Apr 21 09:23:40 2001
++++ ntp-4.0.99m-rc2/ntpd/ntpd.c Thu Aug 30 12:32:54 2001
+@@ -6,6 +6,11 @@
+ # include <config.h>
+ #endif
+
++#include <sys/capability.h>
++#include <sys/prctl.h>
++#include <pwd.h>
++#include <grp.h>
++
+ #include "ntp_machine.h"
+ #include "ntpd.h"
+ #include "ntp_io.h"
+@@ -96,6 +101,11 @@
+ #include "ntp_crypto.h"
+ #endif /* PUBKEY */
+
++/* Username to run as */
++char *server_user=0;
++/* Chroot to this dir */
++char *chroot_dir=0;
++
+ /*
+ * Signals we catch for debugging. If not debugging we ignore them.
+ */
+@@ -188,10 +198,60 @@
+ char *argv[]
+ )
+ {
++ server_user = NULL;
++ chroot_dir = NULL;
+ return ntpdmain(argc, argv);
+ }
+ #endif
+
++/* This patch is adapted (copied) from Chris Wings drop root patch
++ * for xntpd.
++ */
++void drop_root(uid_t server_uid, gid_t server_gid)
++{
++ cap_t caps;
++
++ if (prctl(PR_SET_KEEPCAPS, 1)) {
++ msyslog(LOG_ERR, "prctl(PR_SET_KEEPCAPS, 1) failed");
++ exit(1);
++ }
++
++ if ( setgroups(0, NULL) == -1 ) {
++ msyslog(LOG_ERR, "setgroups failed.");
++ exit(1);
++ }
++
++ if ( setegid(server_gid) == -1 || seteuid(server_uid) == -1 ) {
++ msyslog(LOG_ERR, "setegid/seteuid to uid=%d/gid=%d failed.", server_uid,
++ server_gid);
++ exit(1);
++ }
++
++ caps = cap_from_text("cap_sys_time=epi");
++ if (caps == NULL) {
++ msyslog(LOG_ERR, "cap_from_text failed.");
++ exit(1);
++ }
++
++ if (cap_set_proc(caps) == -1) {
++ msyslog(LOG_ERR, "cap_set_proc failed.");
++ exit(1);
++ }
++
++ /* Try to free the memory from cap_from_text */
++ cap_free( caps );
++
++ if ( setregid(server_gid, server_gid) == -1 ||
++ setreuid(server_uid, server_uid) == -1 ) {
++ msyslog(LOG_ERR, "setregid/setreuid to uid=%d/gid=%d failed.", server_uid,
++ server_gid);
++ exit(1);
++ }
++
++ msyslog(LOG_DEBUG, "running as uid(%d)/gid(%d) euid(%d)/egid(%d).",
++ getuid(), getgid(), geteuid(), getegid());
++}
++
+ #ifdef _AIX
+ /*
+ * OK. AIX is different than solaris in how it implements plock().
+@@ -337,6 +397,9 @@
+ #ifdef _AIX /* HMS: ifdef SIGDANGER? */
+ struct sigaction sa;
+ #endif
++ struct passwd *pwd = NULL;
++ uid_t server_uid;
++ gid_t server_gid;
+
+ initializing = 1; /* mark that we are initializing */
+ debug = 0; /* no debugging by default */
+@@ -377,6 +440,29 @@
+ #endif
+ getstartup(argc, argv); /* startup configuration, may set debug */
+
++ /* Lookup server_user uid/gid before chroot/chdir */
++ if ( server_user ) {
++ pwd = getpwnam( server_user );
++ if ( pwd == NULL ) {
++ msyslog(LOG_ERR, "Failed to lookup user '%s'.", server_user);
++ exit(1);
++ }
++ server_uid = pwd->pw_uid;
++ server_gid = pwd->pw_gid;
++ }
++
++ /* Try to chroot to chroot_dir. This probably makes sense only if
++ * the server drops root privileges.
++ */
++ if ( chroot_dir ) {
++ if ( chroot(chroot_dir) == -1 || chdir("/") == -1 ) {
++ msyslog(LOG_ERR, "chroot/chdir to '%s' failed.", chroot_dir);
++ exit(1);
++ }
++ /* Close /dev/log */
++ closelog();
++ }
++
+ /*
+ * Initialize random generator and public key pair
+ */
+@@ -745,6 +831,10 @@
+ #endif /* AUTOKEY */
+ initializing = 0;
+
++ if ( server_user ) {
++ drop_root( server_uid, server_gid );
++ }
++
+ #if defined(SYS_WINNT) && !defined(NODETACH)
+ # if defined(DEBUG)
+ if(!debug)
+--- ntp-4.0.99m-rc2/ntpd/cmd_args.c.droproot Fri Apr 20 00:50:01 2001
++++ ntp-4.0.99m-rc2/ntpd/cmd_args.c Thu Aug 30 12:34:33 2001
+@@ -15,7 +15,15 @@
+ extern char const *progname;
+ int listen_to_virtual_ips = 0;
+
++static const char *ntp_options = "aAbc:dD:f:gk:l:LmnN:p:P:qr:s:t:v:V:x-:U:T:";
++
++/* Drop root patch */
++extern char *server_user;
++extern char *chroot_dir;
++
++/*
+ static const char *ntp_options = "aAbc:dD:f:gk:l:LmnN:p:P:qr:s:t:v:V:x-:";
++*/
+
+ #ifdef HAVE_NETINFO
+ extern int check_netinfo;
+@@ -114,7 +122,31 @@
+ ++errflg;
+ break;
+
+- default:
++ case 'U':
++ if ( !ntp_optarg ) {
++ fprintf(stderr, "Error: Need username with 'U' option\n");
++ exit(1);
++ }
++ else {
++ if ( !server_user ) {
++ server_user = strdup(ntp_optarg);
++ }
++ }
++ break;
++
++ case 'T':
++ if ( !ntp_optarg ) {
++ fprintf(stderr, "Error: Need directory with 'T' option\n");
++ exit(1);
++ }
++ else {
++ if ( !chroot_dir ) {
++ chroot_dir = strdup(ntp_optarg);
++ }
++ }
++ break;
++
++ default:
+ break;
+ }
+
+@@ -123,6 +155,7 @@
+ (void) fprintf(stderr, "\t\t[ -f freq_file ] [ -k key_file ] [ -l log_file ]\n");
+ (void) fprintf(stderr, "\t\t[ -p pid_file ] [ -r broad_delay ] [ -s statdir ]\n");
+ (void) fprintf(stderr, "\t\t[ -t trust_key ] [ -v sys_var ] [ -V default_sysvar ]\n");
++ (void) fprintf(stderr, "\t\t[ -T chroot_dir ] [ -U server_user ]\n");
+ #if defined(HAVE_SCHED_SETSCHEDULER)
+ (void) fprintf(stderr, "\t\t[ -P fixed_process_priority ]\n");
+ #endif
+@@ -293,6 +326,10 @@
+ allow_step = FALSE;
+ break;
+
++ case 'U': /* already done at pre-scan */
++ case 'T': /* already done at pre-scan */
++ break;
++
+ default:
+ errflg++;
+ break;
+@@ -304,6 +341,7 @@
+ (void) fprintf(stderr, "\t\t[ -f freq_file ] [ -k key_file ] [ -l log_file ]\n");
+ (void) fprintf(stderr, "\t\t[ -p pid_file ] [ -r broad_delay ] [ -s statdir ]\n");
+ (void) fprintf(stderr, "\t\t[ -t trust_key ] [ -v sys_var ] [ -V default_sysvar ]\n");
++ (void) fprintf(stderr, "\t\t[ -T chroot_dir ] [ -U server_user ]\n");
+ #if defined(HAVE_SCHED_SETSCHEDULER)
+ (void) fprintf(stderr, "\t\t[ -P fixed_process_priority ]\n");
+ #endif
+--- ntp-4.1.2/ntpdate/Makefile.am.orig 2003-08-06 02:12:54.000000000 -0400
++++ ntp-4.1.2/ntpdate/Makefile.am 2003-08-06 02:13:59.000000000 -0400
+@@ -5,6 +5,7 @@
+ INCLUDES = -I$(top_srcdir)/include
+ # LDADD might need RESLIB and ADJLIB
+ LDADD = version.o ../libntp/libntp.a @LIBRSAREF@
++ntpdate_LDADD = $(LDADD) -lcap
+ DISTCLEANFILES = .version version.c stamp-v
+ noinst_HEADERS = ntpdate.h
+ #EXTRA_DIST = ntpdate.mak
+--- ntp-4.0.99m-rc2/ntpdate/ntpdate.c.droproot Sun Apr 22 11:42:48 2001
++++ ntp-4.0.99m-rc2/ntpdate/ntpdate.c Thu Aug 30 12:29:04 2001
+@@ -41,6 +41,12 @@
+ # include <sys/resource.h>
+ #endif /* HAVE_SYS_RESOURCE_H */
+
++/* Linux capabilities */
++#include <sys/capability.h>
++#include <sys/prctl.h>
++#include <pwd.h>
++#include <grp.h>
++
+ #ifdef SYS_VXWORKS
+ # include "ioLib.h"
+ # include "sockLib.h"
+@@ -127,6 +133,11 @@
+ int rate = 0;
+
+ /*
++ * Use capabilities to drop privileges and switch uids
++ */
++char *server_user;
++
++/*
+ * Program name.
+ */
+ char *progname;
+@@ -273,6 +284,88 @@
+ static ni_namelist *getnetinfoservers P((void));
+ #endif
+
++/* This patch is adapted (copied) from Chris Wings drop root patch
++ * for xntpd.
++ */
++void drop_root(uid_t server_uid, gid_t server_gid)
++{
++ cap_t caps;
++
++ if (prctl(PR_SET_KEEPCAPS, 1)) {
++ if (syslogit) {
++ msyslog(LOG_ERR, "prctl(PR_SET_KEEPCAPS, 1) failed");
++ }
++ else {
++ fprintf(stderr, "prctl(PR_SET_KEEPCAPS, 1) failed.\n");
++ }
++ exit(1);
++ }
++
++ if ( setgroups(0, NULL) == -1 ) {
++ if (syslogit) {
++ msyslog(LOG_ERR, "setgroups failed.");
++ }
++ else {
++ fprintf(stderr, "setgroups failed.\n");
++ }
++ exit(1);
++ }
++
++ if ( setegid(server_gid) == -1 || seteuid(server_uid) == -1 ) {
++ if (syslogit) {
++ msyslog(LOG_ERR, "setegid/seteuid to uid=%d/gid=%d failed.", server_uid,
++ server_gid);
++ }
++ else {
++ fprintf(stderr, "setegid/seteuid to uid=%d/gid=%d failed.\n", server_uid,
++ server_gid);
++ }
++ exit(1);
++ }
++
++ caps = cap_from_text("cap_sys_time=epi");
++ if (caps == NULL) {
++ if (syslogit) {
++ msyslog(LOG_ERR, "cap_from_text failed.");
++ }
++ else {
++ fprintf(stderr, "cap_from_text failed.\n");
++ }
++ exit(1);
++ }
++
++ if (cap_set_proc(caps) == -1) {
++ if (syslogit) {
++ msyslog(LOG_ERR, "cap_set_proc failed.");
++ }
++ else {
++ fprintf(stderr, "cap_set_proc failed.\n");
++ }
++ exit(1);
++ }
++
++ /* Try to free the memory from cap_from_text */
++ cap_free( caps );
++
++ if ( setregid(server_gid, server_gid) == -1 ||
++ setreuid(server_uid, server_uid) == -1 ) {
++ if (syslogit) {
++ msyslog(LOG_ERR, "setregid/setreuid to uid=%d/gid=%d failed.",
++ server_uid, server_gid);
++ }
++ else {
++ fprintf(stderr, "setregid/setreuid to uid=%d/gid=%d failed.\n",
++ server_uid, server_gid);
++ }
++ exit(1);
++ }
++
++ if (syslogit) {
++ msyslog(LOG_DEBUG, "running as uid(%d)/gid(%d) euid(%d)/egid(%d).",
++ getuid(), getgid(), geteuid(), getegid());
++ }
++}
++
+ /*
+ * Main program. Initialize us and loop waiting for I/O and/or
+ * timer expiries.
+@@ -323,7 +416,7 @@
+ #ifdef NO_MAIN_ALLOWED
+ clear_globals();
+ #endif
+-
++ server_user = NULL;
+ errflg = 0;
+ progname = argv[0];
+ syslogit = 0;
+@@ -331,7 +424,7 @@
+ /*
+ * Decode argument list
+ */
+- while ((c = ntp_getopt(argc, argv, "a:bBde:k:o:p:qr:st:uv")) != EOF)
++ while ((c = ntp_getopt(argc, argv, "a:bBde:k:o:p:qr:st:uvU:")) != EOF)
+ switch (c)
+ {
+ case 'a':
+@@ -417,13 +510,22 @@
+ case '?':
+ ++errflg;
+ break;
++ case 'U':
++ if (ntp_optarg) {
++ server_user = strdup(ntp_optarg);
++ }
++ else {
++ ++errflg;
++ }
++ break;
++
+ default:
+ break;
+ }
+
+ if (errflg) {
+ (void) fprintf(stderr,
+- "usage: %s [-bBdqsuv] [-a key#] [-e delay] [-k file] [-p samples] [-o version#] [-r rate] [-t timeo] server ...\n",
++ "usage: %s [-bBdqsuv] [-a key#] [-e delay] [-k file] [-p samples] [-o version#] [-r rate] [-t timeo] [-U username] server ...\n",
+ progname);
+ exit(2);
+ }
+@@ -536,6 +638,24 @@
+ initializing = 0;
+
+ was_alarmed = 0;
++
++ if (server_user) {
++ struct passwd *pwd = NULL;
++
++ /* Lookup server_user uid/gid before chroot/chdir */
++ pwd = getpwnam( server_user );
++ if ( pwd == NULL ) {
++ if (syslogit) {
++ msyslog(LOG_ERR, "Failed to lookup user '%s'.", server_user);
++ }
++ else {
++ fprintf(stderr, "Failed to lookup user '%s'.\n", server_user);
++ }
++ exit(1);
++ }
++ drop_root(pwd->pw_uid, pwd->pw_gid);
++ }
++
+ rbuflist = (struct recvbuf *)0;
+ while (complete_servers < sys_numservers) {
+ #ifdef HAVE_POLL_H
diff --git a/net-misc/ntp/files/broadcastclient.patch b/net-misc/ntp/files/broadcastclient.patch
new file mode 100644
index 000000000000..1405a8b8c8d9
--- /dev/null
+++ b/net-misc/ntp/files/broadcastclient.patch
@@ -0,0 +1,12 @@
+--- ntpd/ntp_proto.c.orig 2003-08-06 01:12:02.000000000 -0400
++++ ntpd/ntp_proto.c 2003-08-06 01:12:31.000000000 -0400
+@@ -351,8 +351,7 @@
+ * Discard broadcast packets received on the wildcard interface
+ * or if not enabled as broadcast client.
+ */
+- if (PKT_MODE(pkt->li_vn_mode) == MODE_BROADCAST &&
+- (rbufp->dstadr == any_interface || !sys_bclient))
++ if (PKT_MODE(pkt->li_vn_mode) == MODE_BROADCAST && (!sys_bclient))
+ return;
+
+ /*
diff --git a/net-misc/ntp/files/digest-ntp-4.1.2 b/net-misc/ntp/files/digest-ntp-4.1.2
new file mode 100644
index 000000000000..3991a65ff918
--- /dev/null
+++ b/net-misc/ntp/files/digest-ntp-4.1.2
@@ -0,0 +1,2 @@
+MD5 98e16c7aa4ecd4c004b51bff18962e95 ntp-4.1.2.tar.gz 2168384
+MD5 66f59d0eef99784e14b78157c87b97fa ntp-4.1.2-manpages.tbz2 19961
diff --git a/net-misc/ntp/files/ntp-client.confd b/net-misc/ntp/files/ntp-client.confd
new file mode 100644
index 000000000000..0760fd5c0cd4
--- /dev/null
+++ b/net-misc/ntp/files/ntp-client.confd
@@ -0,0 +1,22 @@
+# Copyright 1999-2002 Gentoo Technologies, Inc.
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/net-misc/ntp/files/ntp-client.confd,v 1.1 2003/08/06 07:42:24 vapier Exp $
+
+# Command to run to set the clock initially
+# Most people should just leave this line alone ...
+# however, if you know what you're doing, and you
+# want to use ntpd to set the clock, change this to 'ntpd'
+NTPCLIENT_CMD="ntpdate"
+
+# Options to pass to the above command
+# Most people should just uncomment this variable and
+# change 'someserver' to a valid hostname which you
+# can aquire from the URL's below
+#NTPCLIENT_OPTS="-b someserver"
+
+##
+# A list of available servers is available here:
+# http://www.eecis.udel.edu/~mills/ntp/servers.html
+# Please follow the rules of engagement and use a
+# Stratum 2 server (unless you qualify for Stratum 1)
+##
diff --git a/net-misc/ntp/files/ntp-client.rc b/net-misc/ntp/files/ntp-client.rc
new file mode 100644
index 000000000000..b6f0be48b003
--- /dev/null
+++ b/net-misc/ntp/files/ntp-client.rc
@@ -0,0 +1,31 @@
+#!/sbin/runscript
+# Copyright 1999-2003 Gentoo Technologies, Inc.
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/net-misc/ntp/files/ntp-client.rc,v 1.1 2003/08/06 07:42:24 vapier Exp $
+
+depend() {
+ need net
+ use dns logger
+}
+
+checkconfig() {
+ if [ ! -x "`which ${NTPCLIENT_CMD} 2>/dev/null`" ] ; then
+ eerror "Please edit /etc/conf.d/ntp-client"
+ eerror "Unable to locate the client command ${NTPCLIENT_CMD}!"
+ return 1
+ fi
+ if [ -z "${NTPCLIENT_OPTS}" ] ; then
+ eerror "Please edit /etc/conf.d/ntp-client"
+ eerror "I need to know what server/options to use!"
+ return 1
+ fi
+ return 0
+}
+
+start() {
+ checkconfig || return $?
+
+ ebegin "Setting clock via the ntp client '${NTPCLIENT_CMD}'"
+ ${NTPCLIENT_CMD} >/dev/null ${NTPCLIENT_OPTS}
+ eend $? "Failed to set clock"
+}
diff --git a/net-misc/ntp/files/ntpd-4.1.1b.confd b/net-misc/ntp/files/ntpd-4.1.1b.confd
new file mode 100644
index 000000000000..bb518a2a872b
--- /dev/null
+++ b/net-misc/ntp/files/ntpd-4.1.1b.confd
@@ -0,0 +1,40 @@
+# Copyright 1999-2002 Gentoo Technologies, Inc.
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/net-misc/ntp/files/ntpd-4.1.1b.confd,v 1.1 2003/08/06 07:42:24 vapier Exp $
+
+# NOTES:
+# - NTPDATE variables below are used if you wish to set your
+# clock when you start the ntp init.d script
+# - make sure that the NTPDATE_CMD will close by itself ...
+# the init.d script will not attempt to kill/stop it
+# - ntpd will be used to maintain synchronization with a time
+# server regardless of what NTPDATE is set to
+# - read each of the comments above each of the variable
+
+# Comment this out if you dont want the init script to warn
+# about not having ntpdate setup
+NTPDATE_WARN="y"
+
+# Command to run to set the clock initially
+# Most people should just uncomment this line ...
+# however, if you know what you're doing, and you
+# want to use ntpd to set the clock, change this to 'ntpd'
+#NTPDATE_CMD="ntpdate"
+
+# Options to pass to the above command
+# Most people should just uncomment this variable and
+# change 'someserver' to a valid hostname which you
+# can aquire from the URL's below
+#NTPDATE_OPTS="-b someserver"
+
+##
+# A list of available servers is available here:
+# http://www.eecis.udel.edu/~mills/ntp/servers.html
+# Please follow the rules of engagement and use a
+# Stratum 2 server (unless you qualify for Stratum 1)
+##
+
+# Options to pass to the ntpd process that will *always* be run
+# Most people should not uncomment this line ...
+# however, if you know what you're doing, feel free to tweak
+#NTPD_OPTS=""
diff --git a/net-misc/ntp/files/ntpd-4.1.1b.rc b/net-misc/ntp/files/ntpd-4.1.1b.rc
new file mode 100644
index 000000000000..455cc7b19514
--- /dev/null
+++ b/net-misc/ntp/files/ntpd-4.1.1b.rc
@@ -0,0 +1,44 @@
+#!/sbin/runscript
+# Copyright 1999-2003 Gentoo Technologies, Inc.
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/net-misc/ntp/files/ntpd-4.1.1b.rc,v 1.1 2003/08/06 07:42:24 vapier Exp $
+
+depend() {
+ need net
+ use dns logger
+}
+
+checkconfig() {
+ if [ ! -f /etc/ntp.conf ] ; then
+ eerror "Please create /etc/ntp.conf"
+ eerror "Sample conf: /usr/share/ntp/ntp.conf"
+ return 1
+ fi
+ return 0
+}
+
+start() {
+ checkconfig || return $?
+
+ if [ -n "${NTPDATE_CMD}" ] ; then
+ ebegin "Initializing clock via ${NTPDATE_CMD}"
+ ${NTPDATE_CMD} ${NTPDATE_OPTS} > /dev/null
+ eend $? "Failed to run ${NTPDATE_CMD}"
+ elif [ "${NTPDATE_WARN}" == "y" ] ; then
+ ewarn "Please setup ntpd via /etc/conf.d/ntpd"
+ fi
+
+ ebegin "Starting ntpd"
+ start-stop-daemon --start --quiet --pidfile /var/run/ntpd.pid \
+ --startas /usr/bin/ntpd -- -p /var/run/ntpd.pid ${NTPD_OPTS}
+ eend $? "Failed to start ntpd"
+}
+
+stop() {
+ ebegin "Stopping ntpd"
+ start-stop-daemon --stop --quiet --pidfile /var/run/ntpd.pid
+ eend $? "Failed to stop ntpd"
+
+ # clean stale pidfile
+ [ -f /var/run/ntpd.pid ] && rm -f /var/run/ntpd.pid
+}
diff --git a/net-misc/ntp/files/ntpd.confd b/net-misc/ntp/files/ntpd.confd
index f2b5b392f776..4925ded05434 100644
--- a/net-misc/ntp/files/ntpd.confd
+++ b/net-misc/ntp/files/ntpd.confd
@@ -1,40 +1,8 @@
# Copyright 1999-2002 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/net-misc/ntp/files/ntpd.confd,v 1.12 2003/02/03 06:52:58 vapier Exp $
+# $Header: /var/cvsroot/gentoo-x86/net-misc/ntp/files/ntpd.confd,v 1.13 2003/08/06 07:42:24 vapier Exp $
-# NOTES:
-# - NTPDATE variables below are used if you wish to set your
-# clock when you start the ntp init.d script
-# - make sure that the NTPDATE_CMD will close by itself ...
-# the init.d script will not attempt to kill/stop it
-# - ntpd will be used to maintain synchronization with a time
-# server regardless of what NTPDATE is set to
-# - read each of the comments above each of the variable
-
-# Comment this out if you dont want the init script to warn
-# about not having ntpdate setup
-NTPDATE_WARN="y"
-
-# Command to run to set the clock initially
-# Most people should just uncomment this line ...
-# however, if you know what you're doing, and you
-# want to use ntpd to set the clock, change this to 'ntpd'
-#NTPDATE_CMD="ntpdate"
-
-# Options to pass to the above command
-# Most people should just uncomment this variable and
-# change 'someserver' to a valid hostname which you
-# can aquire from the URL's below
-#NTPDATE_OPTS="-b someserver"
-
-##
-# A list of available servers is available here:
-# http://www.eecis.udel.edu/~mills/ntp/servers.html
-# Please follow the rules of engagement and use a
-# Stratum 2 server (unless you qualify for Stratum 1)
-##
-
-# Options to pass to the ntpd process that will *always* be run
-# Most people should not uncomment this line ...
+# Options to pass to the ntpd process
+# Most people should leave this line alone ...
# however, if you know what you're doing, feel free to tweak
-#NTPD_OPTS=""
+NTPD_OPTS="-U ntp"
diff --git a/net-misc/ntp/files/ntpd.rc b/net-misc/ntp/files/ntpd.rc
index 77292ba8979b..6fe704fa17dc 100644
--- a/net-misc/ntp/files/ntpd.rc
+++ b/net-misc/ntp/files/ntpd.rc
@@ -1,11 +1,12 @@
#!/sbin/runscript
# Copyright 1999-2003 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/net-misc/ntp/files/ntpd.rc,v 1.12 2003/02/14 23:06:19 vapier Exp $
+# $Header: /var/cvsroot/gentoo-x86/net-misc/ntp/files/ntpd.rc,v 1.13 2003/08/06 07:42:24 vapier Exp $
depend() {
need net
use dns logger
+ after ntp-client
}
checkconfig() {
@@ -20,14 +21,6 @@ checkconfig() {
start() {
checkconfig || return $?
- if [ -n "${NTPDATE_CMD}" ] ; then
- ebegin "Initializing clock via ${NTPDATE_CMD}"
- ${NTPDATE_CMD} ${NTPDATE_OPTS} > /dev/null
- eend $? "Failed to run ${NTPDATE_CMD}"
- elif [ "${NTPDATE_WARN}" == "y" ] ; then
- ewarn "Please setup ntpd via /etc/conf.d/ntpd"
- fi
-
ebegin "Starting ntpd"
start-stop-daemon --start --quiet --pidfile /var/run/ntpd.pid \
--startas /usr/bin/ntpd -- -p /var/run/ntpd.pid ${NTPD_OPTS}
diff --git a/net-misc/ntp/ntp-4.1.1b-r6.ebuild b/net-misc/ntp/ntp-4.1.1b-r6.ebuild
index f56a4622c239..20846492e06a 100644
--- a/net-misc/ntp/ntp-4.1.1b-r6.ebuild
+++ b/net-misc/ntp/ntp-4.1.1b-r6.ebuild
@@ -1,6 +1,6 @@
# Copyright 1999-2003 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/net-misc/ntp/ntp-4.1.1b-r6.ebuild,v 1.3 2003/07/18 20:59:07 tester Exp $
+# $Header: /var/cvsroot/gentoo-x86/net-misc/ntp/ntp-4.1.1b-r6.ebuild,v 1.4 2003/08/06 07:42:24 vapier Exp $
inherit eutils
@@ -55,8 +55,8 @@ src_install() {
-name support`
mv scripts/* ${D}/usr/share/ntp/
- exeinto /etc/init.d ; newexe ${FILESDIR}/ntpd.rc ntpd
- insinto /etc/conf.d ; newins ${FILESDIR}/ntpd.confd ntpd
+ exeinto /etc/init.d ; newexe ${FILESDIR}/ntpd-${PV}.rc ntpd
+ insinto /etc/conf.d ; newins ${FILESDIR}/ntpd-${PV}.confd ntpd
}
pkg_postinst() {
diff --git a/net-misc/ntp/ntp-4.1.2.ebuild b/net-misc/ntp/ntp-4.1.2.ebuild
new file mode 100644
index 000000000000..c38a3317f78c
--- /dev/null
+++ b/net-misc/ntp/ntp-4.1.2.ebuild
@@ -0,0 +1,105 @@
+# Copyright 1999-2003 Gentoo Technologies, Inc.
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/net-misc/ntp/ntp-4.1.2.ebuild,v 1.1 2003/08/06 07:42:24 vapier Exp $
+
+inherit eutils
+
+DESCRIPTION="Network Time Protocol suite/programs"
+HOMEPAGE="http://www.ntp.org/"
+SRC_URI="http://www.eecis.udel.edu/~ntp/ntp_spool/ntp4/${P}.tar.gz
+ mirror://gentoo/${PF}-manpages.tbz2"
+
+LICENSE="as-is"
+SLOT="0"
+KEYWORDS="~x86 ~ppc ~sparc ~mips ~alpha ~arm ~hppa ~amd64"
+IUSE="parse-clocks ssl"
+
+DEPEND=">=sys-apps/sed-4.0.5
+ >=sys-libs/ncurses-5.2
+ >=sys-libs/readline-4.1
+ sys-libs/libcap
+ ssl? ( dev-libs/openssl )"
+
+pkg_setup() {
+ enewgroup ntp 123
+ enewuser ntp 123 /dev/null /bin/false ntp
+}
+
+hax_bitkeeper() {
+ # the makefiles have support for bk ...
+ # basically we have to do this or bk will try to write
+ # to files in /opt/bitkeeper causing sandbox violations ;(
+ mkdir ${T}/fakebin
+ echo "#!/bin/sh"$'\n'"exit 1" > ${T}/fakebin/bk
+ chmod a+x ${T}/fakebin/bk
+ export PATH="${T}/fakebin:${PATH}"
+}
+
+src_unpack() {
+ unpack ${A}
+ cd ${S}
+
+ use alpha && epatch ${FILESDIR}/ntp-4.1.1b-syscall-libc.patch
+ epatch ${FILESDIR}/broadcastclient.patch #17336
+ epatch ${FILESDIR}/${PV}-droproot.patch #21444
+
+ epatch ${FILESDIR}/linux-config-phone.patch #13001
+ sed -i "s:-Wpointer-arith::" configure.in
+
+ aclocal -I . || die
+ automake || die
+ autoconf || die
+}
+
+src_compile() {
+ hax_bitkeeper
+
+ local mysslconf
+ use ssl \
+ && mysslconf="--with-openssl-libdir=yes" \
+ || mysslconf="--with-openssl-libdir=no"
+ econf \
+ --build=${CHOST} \
+ `use_enable parse-clocks` \
+ ${mysslconf} \
+ || die
+ emake || die
+}
+
+src_install() {
+ hax_bitkeeper
+
+ make install DESTDIR=${D} || die
+
+ dodoc ChangeLog INSTALL NEWS README TODO WHERE-TO-START
+ doman ${WORKDIR}/man/*.1
+ dohtml -r html/*
+
+ insinto /usr/share/ntp
+ doins ${FILESDIR}/ntp.conf
+ rm -rf `find scripts/ \
+ -name '*.in' -o \
+ -name 'Makefile*' -o \
+ -name 'rc[12]' -o \
+ -name support`
+ mv scripts/* ${D}/usr/share/ntp/
+
+ [ ! -e /etc/ntp.conf ] && insinto /etc && doins ${FILESDIR}/ntp.conf
+ exeinto /etc/init.d
+ newexe ${FILESDIR}/ntpd.rc ntpd
+ newexe ${FILESDIR}/ntp-client.rc ntp-client
+ insinto /etc/conf.d
+ newins ${FILESDIR}/ntpd.confd ntpd
+ newins ${FILESDIR}/ntp-client.confd ntp-client
+}
+
+pkg_postinst() {
+ ewarn "You can find an example /etc/ntp.conf in /usr/share/ntp/"
+ ewarn "Review /etc/ntp.conf to setup server info."
+ ewarn "Review /etc/conf.d/ntpd to setup init.d info."
+ echo
+ einfo "The way ntp sets and maintains your system time has changed."
+ einfo "Now you can use /etc/init.d/ntp-client to set your time at"
+ einfo "boot while you can use /etc/init.d/ntpd to maintain your time"
+ einfo "while your machine runs"
+}