diff options
author | pi <pi@FreeBSD.org> | 2016-05-08 09:33:26 +0000 |
---|---|---|
committer | pi <pi@FreeBSD.org> | 2016-05-08 09:33:26 +0000 |
commit | 80b91a5cda572b4fa96b99ce203807e5a0b91bda (patch) | |
tree | 821c465a7112fc7fafa33b298c44fafe53b13014 | |
parent | 0aa1f20343ad8e28ab310f9380e24d03ac8eaecf (diff) | |
download | FreeBSD-ports-80b91a5cda572b4fa96b99ce203807e5a0b91bda.zip FreeBSD-ports-80b91a5cda572b4fa96b99ce203807e5a0b91bda.tar.gz |
sysutils/fcron: 3.0.6 -> 3.2.0
Changes:
http://fcron.free.fr/doc/en/changes.html
- updated maintainer mail
PR: 209139
Submitted by: bob@eager.cx (maintainer)
-rw-r--r-- | sysutils/fcron/Makefile | 41 | ||||
-rw-r--r-- | sysutils/fcron/distinfo | 4 | ||||
-rw-r--r-- | sysutils/fcron/files/fcron.in | 11 | ||||
-rw-r--r-- | sysutils/fcron/files/patch-configure | 11 | ||||
-rw-r--r-- | sysutils/fcron/files/patch-doc_en_man_fcron.8 | 13 | ||||
-rw-r--r-- | sysutils/fcron/files/patch-doc_en_man_fcron.conf.5 | 20 | ||||
-rw-r--r-- | sysutils/fcron/files/patch-doc_en_man_fcrontab.1 | 11 | ||||
-rw-r--r-- | sysutils/fcron/files/patch-doc_fr_man_fcron.8 | 13 | ||||
-rw-r--r-- | sysutils/fcron/files/patch-fcrondyn.c | 23 | ||||
-rw-r--r-- | sysutils/fcron/files/patch-fileconf.c | 14 | ||||
-rw-r--r-- | sysutils/fcron/files/patch-files_fcron.pam | 8 | ||||
-rw-r--r-- | sysutils/fcron/files/patch-m4_ax__lib__readline.m4 | 11 | ||||
-rw-r--r-- | sysutils/fcron/files/patch-save.c | 15 | ||||
-rw-r--r-- | sysutils/fcron/files/patch-subs.c | 28 | ||||
-rw-r--r-- | sysutils/fcron/pkg-plist | 3 |
15 files changed, 166 insertions, 60 deletions
diff --git a/sysutils/fcron/Makefile b/sysutils/fcron/Makefile index c6b6733..960ade9 100644 --- a/sysutils/fcron/Makefile +++ b/sysutils/fcron/Makefile @@ -1,66 +1,69 @@ -# Created by: Ying-Chieh Liao <ijliao@FreeBSD.org> # $FreeBSD$ PORTNAME= fcron -PORTVERSION= 3.0.6 -PORTREVISION= 2 +PORTVERSION= 3.2.0 CATEGORIES= sysutils -MASTER_SITES= SUNSITE/system/daemons/cron \ - http://fcron.free.fr/archives/ \ +MASTER_SITES= http://fcron.free.fr/archives/ \ ftp://ftp.seul.org/pub/fcron/ DISTNAME= ${PORTNAME}-${PORTVERSION}.src -MAINTAINER= rde@tavi.co.uk +MAINTAINER= bob@eager.cx COMMENT= Periodic command scheduler +LICENSE= GPLv2 + OPTIONS_DEFINE= DOCS EXAMPLES GNU_CONFIGURE= yes USES= perl5 gmake USE_PERL5= build -CONFIGURE_ARGS= --with-etcdir=${PREFIX}/etc --localstatedir=/var \ +CONFIGURE_ARGS= --localstatedir=/var \ --with-cflags="${CFLAGS}" \ --with-rootname=root --with-rootgroup=wheel \ - --with-docdir=${DOCSDIR} + --with-docdir=${DOCSDIR} \ + --with-dsssl-dir=no -WRKSRC= ${WRKDIR}/fcron-${PORTVERSION} +WRKSRC= ${WRKDIR}/${PORTNAME}-${PORTVERSION} USERS= fcron GROUPS= fcron USE_RC_SUBR= fcron + SUB_FILES= pkg-message -PAMDIR?= /etc/pam.d +PAMDIR?= etc/pam.d PLIST_SUB+= PAMDIR=etc/pam.d PORTDOCS= * -.if defined(MANLANG) && exists(${WRKSRC}/doc/${MANLANG}) -DOCSRC= ${WRKSRC}/doc/${MANLANG} -.else DOCSRC= ${WRKSRC}/doc/en -.endif do-install: ${INSTALL_PROGRAM} ${WRKSRC}/fcron ${STAGEDIR}${PREFIX}/sbin ${INSTALL_PROGRAM} ${WRKSRC}/fcrontab ${STAGEDIR}${PREFIX}/bin ${INSTALL_PROGRAM} ${WRKSRC}/fcrondyn ${STAGEDIR}${PREFIX}/bin ${INSTALL_PROGRAM} ${WRKSRC}/fcronsighup ${STAGEDIR}${PREFIX}/bin + ${INSTALL_DATA} ${WRKSRC}/files/fcron.pam ${STAGEDIR}${PREFIX}/${PAMDIR}/fcron + ${INSTALL_DATA} ${WRKSRC}/files/fcrontab.pam ${STAGEDIR}${PREFIX}/${PAMDIR}/fcrontab .for f in fcron.allow fcron.conf fcron.deny ${INSTALL_DATA} -m 640 ${WRKSRC}/files/${f} ${STAGEDIR}${PREFIX}/etc/${f}.sample .endfor - ${MKDIR} ${STAGEDIR}${EXAMPLESDIR} - ${INSTALL_DATA} ${FILESDIR}/fcrontab-* ${WRKSRC}/files/*.pam ${STAGEDIR}${EXAMPLESDIR} - ${INSTALL_DATA} ${WRKSRC}/files/fcron.pam ${STAGEDIR}${PREFIX}${PAMDIR}/fcron - ${INSTALL_DATA} ${WRKSRC}/files/fcrontab.pam ${STAGEDIR}${PREFIX}${PAMDIR}/fcrontab - install -d -m 770 ${STAGEDIR}/var/spool/fcron .for n in 1 5 8 ${INSTALL_MAN} ${DOCSRC}/man/*.${n} ${STAGEDIR}${PREFIX}/man/man${n} .endfor + +do-install-EXAMPLES-on: + ${MKDIR} ${STAGEDIR}${EXAMPLESDIR} + ${INSTALL_DATA} ${FILESDIR}/fcrontab-* ${WRKSRC}/files/*.pam ${STAGEDIR}${EXAMPLESDIR} + +do-install-DOCS-on: .for d in txt HTML ${MKDIR} ${STAGEDIR}${DOCSDIR}/${d} ${INSTALL_DATA} ${DOCSRC}/${d}/* ${STAGEDIR}${DOCSDIR}/${d} .endfor +post-install: + ${MKDIR} -m 770 ${STAGEDIR}/var/spool/fcron + .include <bsd.port.mk> diff --git a/sysutils/fcron/distinfo b/sysutils/fcron/distinfo index 89b98e9..307d486 100644 --- a/sysutils/fcron/distinfo +++ b/sysutils/fcron/distinfo @@ -1,2 +1,2 @@ -SHA256 (fcron-3.0.6.src.tar.gz) = 9c36b1bc6c931ec8b4ef55fef569ba17004b32f3ae0a72e3cc4ec4d15bee30a1 -SIZE (fcron-3.0.6.src.tar.gz) = 552805 +SHA256 (fcron-3.2.0.src.tar.gz) = eb13b86ed96805d117e19847f1da30b834f1990f7ef4c38f5007234d44679564 +SIZE (fcron-3.2.0.src.tar.gz) = 595408 diff --git a/sysutils/fcron/files/fcron.in b/sysutils/fcron/files/fcron.in index 0faf3935..1c69856 100644 --- a/sysutils/fcron/files/fcron.in +++ b/sysutils/fcron/files/fcron.in @@ -2,18 +2,23 @@ # # $FreeBSD$ # - # PROVIDE: fcron # REQUIRE: LOGIN # BEFORE: securelevel # KEYWORD: shutdown +# +# fcron_enable (bool): Set to NO by default. +# Set it to YES to enable fcron. . /etc/rc.subr -name="fcron" +desc="Periodic command scheduler" +name=fcron rcvar=fcron_enable + +load_rc_config $name + command="%%PREFIX%%/sbin/${name}" pidfile="/var/run/${name}.pid" -load_rc_config $name run_rc_command "$1" diff --git a/sysutils/fcron/files/patch-configure b/sysutils/fcron/files/patch-configure new file mode 100644 index 0000000..e96c7cf --- /dev/null +++ b/sysutils/fcron/files/patch-configure @@ -0,0 +1,11 @@ +--- configure.orig 2014-07-06 10:05:56 UTC ++++ configure +@@ -5153,7 +5153,7 @@ if ${ax_cv_lib_readline+:} false; then : + else + + ORIG_LIBS="$LIBS" +- for readline_lib in readline edit editline; do ++ for readline_lib in readline editline; do + for termcap_lib in "" termcap curses ncurses; do + if test -z "$termcap_lib"; then + TRY_LIB="-l$readline_lib" diff --git a/sysutils/fcron/files/patch-doc_en_man_fcron.8 b/sysutils/fcron/files/patch-doc_en_man_fcron.8 new file mode 100644 index 0000000..92a39f2 --- /dev/null +++ b/sysutils/fcron/files/patch-doc_en_man_fcron.8 @@ -0,0 +1,13 @@ +--- doc/en/man/fcron.8.orig 2014-07-06 10:10:37 UTC ++++ doc/en/man/fcron.8 +@@ -25,8 +25,8 @@ fcron \- daemon to execute scheduled tas + + .SH "DESCRIPTION" + .PP +-\fBFcron\fR should be started from \fI/etc/rc\fR or +-\fI/etc/rc.local\fR\&. Unless the \fB-f\fR (or ++\fBFcron\fR should be started from \fI/etc/rc.d\fR or ++\fI/usr/local/etc/rc.d\fR\&. Unless the \fB-f\fR (or + \fB--foreground\fR) option is given, it will return immediately, so + you don't need to start it with '&'. + .PP diff --git a/sysutils/fcron/files/patch-doc_en_man_fcron.conf.5 b/sysutils/fcron/files/patch-doc_en_man_fcron.conf.5 new file mode 100644 index 0000000..7de9a66 --- /dev/null +++ b/sysutils/fcron/files/patch-doc_en_man_fcron.conf.5 @@ -0,0 +1,20 @@ +--- doc/en/man/fcron.conf.5.orig 2014-07-06 10:10:37 UTC ++++ doc/en/man/fcron.conf.5 +@@ -27,14 +27,14 @@ optional. Trailing blanks are also ignor + The following names are recognized (default value in parentheses): + "VALID VARIABLES IN A FCRON.CONF FILE" + .TP +-\fBfcrontabs=\fIdirectory\fB (\fI/usr/local/var/spool/fcron\fB)\fR ++\fBfcrontabs=\fIdirectory\fB (\fI/var/spool/fcron\fB)\fR + \fBFcron\fR spool directory. + .TP +-\fBpidfile=\fIfile-path\fB (\fI/usr/local/var/run/fcron.pid\fB)\fR ++\fBpidfile=\fIfile-path\fB (\fI/var/run/fcron.pid\fB)\fR + Location of \fBfcron\fR pid file (needed by \fBfcrontab\fR + to work properly). + .TP +-\fBfifofile=\fIfile-path\fB (\fI/usr/local/var/run/fcron.fifo\fB)\fR ++\fBfifofile=\fIfile-path\fB (\fI/var/run/fcron.fifo\fB)\fR + Location of \fBfcron\fR fifo file (needed by + \fBfcrondyn\fR to communicate with \fBfcron\fR). + .TP diff --git a/sysutils/fcron/files/patch-doc_en_man_fcrontab.1 b/sysutils/fcron/files/patch-doc_en_man_fcrontab.1 new file mode 100644 index 0000000..5d4b53c --- /dev/null +++ b/sysutils/fcron/files/patch-doc_en_man_fcrontab.1 @@ -0,0 +1,11 @@ +--- doc/en/man/fcrontab.1.orig 2014-07-06 10:10:38 UTC ++++ doc/en/man/fcrontab.1 +@@ -32,7 +32,7 @@ and date of next execution), the user ca + .PP + When a user + installs a \fBfcrontab\fR, the source file is saved in the spool +-directory (\fI/usr/local/var/spool/fcron\fR) to allow future ++directory (\fI/var/spool/fcron\fR) to allow future + editions, and a formatted file is generated for the \fBfcron\fR daemon, + which is signaled once about ten seconds before the next minute for + all changes made previously. The daemon is not informed of the changes diff --git a/sysutils/fcron/files/patch-doc_fr_man_fcron.8 b/sysutils/fcron/files/patch-doc_fr_man_fcron.8 new file mode 100644 index 0000000..3315651 --- /dev/null +++ b/sysutils/fcron/files/patch-doc_fr_man_fcron.8 @@ -0,0 +1,13 @@ +--- doc/fr/man/fcron.8.orig 2014-07-06 10:10:39 UTC ++++ doc/fr/man/fcron.8 +@@ -25,8 +25,8 @@ fcron \- démon pour exécuter des tâches + + .SH "DESCRIPTION" + .PP +-\fBFcron\fR devrait être lancé par un script \fI/etc/rc\fR +-ou \fI/etc/rc.local\fR\&. À moins que l'option ++\fBFcron\fR devrait être lancé par un script en \fI/etc/rc.d\fR ++ou \fI/usr/local/etc/rc.d\fR\&. À moins que l'option + \fB-f\fR (ou \fB--foreground\fR) n'ait été fournie, + cette commande rend la main immédiatement. Ainsi, vous n'avez pas besoin + de la lancer avec «\~&\~». diff --git a/sysutils/fcron/files/patch-fcrondyn.c b/sysutils/fcron/files/patch-fcrondyn.c new file mode 100644 index 0000000..4948b08 --- /dev/null +++ b/sysutils/fcron/files/patch-fcrondyn.c @@ -0,0 +1,23 @@ +Fix use of size_t in context where ssize_t (error value included) is +more correct. + +--- fcrondyn.c.orig 2014-05-10 17:03:59 UTC ++++ fcrondyn.c +@@ -482,7 +482,7 @@ talk_fcron(char *cmd_str, int fd) + long int *cmd = NULL; + int cmd_len = 0; + char buf[LINE_LEN]; +- size_t read_len = 0; ++ ssize_t read_len = 0; + char existing_connection = (fd < 0) ? 0 : 1; + fd_set read_set; /* needed to use select to check if some data is waiting */ + struct timeval tv; +@@ -578,7 +578,7 @@ talk_fcron(char *cmd_str, int fd) + } + + +- while ((read_len = (size_t) recv(fd, buf, sizeof(buf) - 1, 0)) >= 0 ++ while ((read_len = (ssize_t) recv(fd, buf, sizeof(buf) - 1, 0)) >= 0 + || errno == EINTR) { + + if (errno == EINTR && debug_opt) diff --git a/sysutils/fcron/files/patch-fileconf.c b/sysutils/fcron/files/patch-fileconf.c index 9255b79..53bff7b 100644 --- a/sysutils/fcron/files/patch-fileconf.c +++ b/sysutils/fcron/files/patch-fileconf.c @@ -1,15 +1,15 @@ We don't need to fflush the file, since it is opened read-only. ---- fileconf.c.orig 2011-07-18 19:55:28.726082293 +0400 -+++ fileconf.c 2011-07-18 19:55:37.988079816 +0400 -@@ -264,10 +264,6 @@ +--- fileconf.c.orig 2014-05-10 17:03:59 UTC ++++ fileconf.c +@@ -278,10 +278,6 @@ read_file(char *filename, int fd) cf->cf_next = file_base; file_base = cf; - /* don't close as underlying fd may still be used by calling function */ - if (fflush(file) != 0) - error_e("could not fflush() file_name"); -- - free(default_line.cl_runas); - free(default_line.cl_mailto); - free(default_line.cl_tz); +- + Free_safe(default_line.cl_runas); + Free_safe(default_line.cl_mailto); + Free_safe(default_line.cl_tz); diff --git a/sysutils/fcron/files/patch-files_fcron.pam b/sysutils/fcron/files/patch-files_fcron.pam new file mode 100644 index 0000000..2f9d011 --- /dev/null +++ b/sysutils/fcron/files/patch-files_fcron.pam @@ -0,0 +1,8 @@ +--- files/fcron.pam.orig 2012-12-05 18:17:00 UTC ++++ files/fcron.pam +@@ -9,4 +9,4 @@ auth required pam_permit.so + #auth required pam_env.so + session required pam_permit.so + #session required pam_unix.so +-session required pam_loginuid.so ++#session required pam_loginuid.so diff --git a/sysutils/fcron/files/patch-m4_ax__lib__readline.m4 b/sysutils/fcron/files/patch-m4_ax__lib__readline.m4 new file mode 100644 index 0000000..b9a8168 --- /dev/null +++ b/sysutils/fcron/files/patch-m4_ax__lib__readline.m4 @@ -0,0 +1,11 @@ +--- m4/ax_lib_readline.m4.orig 2013-01-01 17:47:31 UTC ++++ m4/ax_lib_readline.m4 +@@ -65,7 +65,7 @@ AC_DEFUN([AX_LIB_READLINE], [ + AC_CACHE_CHECK([for a readline compatible library], + ax_cv_lib_readline, [ + ORIG_LIBS="$LIBS" +- for readline_lib in readline edit editline; do ++ for readline_lib in readline editline; do + for termcap_lib in "" termcap curses ncurses; do + if test -z "$termcap_lib"; then + TRY_LIB="-l$readline_lib" diff --git a/sysutils/fcron/files/patch-save.c b/sysutils/fcron/files/patch-save.c new file mode 100644 index 0000000..5ddd720 --- /dev/null +++ b/sysutils/fcron/files/patch-save.c @@ -0,0 +1,15 @@ +Replace fdatasync() with fsync() because FreeBSD doesn't have fdatasync(). + +--- save.c.orig 2014-05-10 17:03:59 UTC ++++ save.c +@@ -311,8 +311,8 @@ write_file_to_disk(int fd, struct cf_t * + * This is to avoid cases where the file name (meta-data) would be updated, + * and there is a crash before the data is fully written: not sure if that + * is possible, but better safe than sorry! */ +- if (fdatasync(fd) < 0) { +- error_e("could not fdatasync() %s's fcrontab", file->cf_user); ++ if (fsync(fd) < 0) { ++ error_e("could not fsync() %s's fcrontab", file->cf_user); + return ERR; + } + diff --git a/sysutils/fcron/files/patch-subs.c b/sysutils/fcron/files/patch-subs.c deleted file mode 100644 index bee359d..0000000 --- a/sysutils/fcron/files/patch-subs.c +++ /dev/null @@ -1,28 +0,0 @@ ---- subs.c.orig 2011-07-18 17:28:21.745080904 +0400 -+++ subs.c 2011-07-18 19:39:18.999087202 +0400 -@@ -121,7 +121,11 @@ - - if (flags & O_CREAT) { - va_start(ap, flags); -- mode = va_arg(ap, mode_t); -+ /* Beware: default argument promotion. */ -+ if (sizeof(int) > sizeof(mode_t)) -+ mode = va_arg(ap, int); -+ else -+ mode = va_arg(ap, mode_t); - va_end(ap); - } - -@@ -179,7 +183,11 @@ - - if (flags & O_CREAT) { - va_start(ap, flags); -- mode = va_arg(ap, mode_t); -+ /* Beware: default argument promotion. */ -+ if (sizeof(int) > sizeof(mode_t)) -+ mode = va_arg(ap, int); -+ else -+ mode = va_arg(ap, mode_t); - va_end(ap); - } - diff --git a/sysutils/fcron/pkg-plist b/sysutils/fcron/pkg-plist index d81efec..dc3787e 100644 --- a/sysutils/fcron/pkg-plist +++ b/sysutils/fcron/pkg-plist @@ -6,8 +6,9 @@ @(,,6111) bin/fcrontab @(,,4110) bin/fcronsighup @sample etc/fcron.allow.sample -@sample etc/fcron.conf.sample @sample etc/fcron.deny.sample +@owner root +@sample etc/fcron.conf.sample @owner @group man/man1/fcrondyn.1.gz |