diff options
-rw-r--r-- | net-misc/ntp/ChangeLog | 9 | ||||
-rw-r--r-- | net-misc/ntp/files/4.1.2-droproot.patch | 476 | ||||
-rw-r--r-- | net-misc/ntp/files/broadcastclient.patch | 12 | ||||
-rw-r--r-- | net-misc/ntp/files/digest-ntp-4.1.2 | 2 | ||||
-rw-r--r-- | net-misc/ntp/files/ntp-client.confd | 22 | ||||
-rw-r--r-- | net-misc/ntp/files/ntp-client.rc | 31 | ||||
-rw-r--r-- | net-misc/ntp/files/ntpd-4.1.1b.confd | 40 | ||||
-rw-r--r-- | net-misc/ntp/files/ntpd-4.1.1b.rc | 44 | ||||
-rw-r--r-- | net-misc/ntp/files/ntpd.confd | 40 | ||||
-rw-r--r-- | net-misc/ntp/files/ntpd.rc | 11 | ||||
-rw-r--r-- | net-misc/ntp/ntp-4.1.1b-r6.ebuild | 6 | ||||
-rw-r--r-- | net-misc/ntp/ntp-4.1.2.ebuild | 105 |
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" +} |