svn commit: r346252 - in head/usr.sbin/cron: cron crontab
Ian Lepore
ian at freebsd.org
Mon Apr 15 19:26:33 UTC 2019
On Mon, 2019-04-15 at 18:53 +0000, Kyle Evans wrote:
> Author: kevans
> Date: Mon Apr 15 18:53:28 2019
> New Revision: 346252
> URL: https://svnweb.freebsd.org/changeset/base/346252
>
> Log:
> cron(8): Add MAILFROM ability for crontabs
>
> This changes the sender mail address in a similar fashion to how MAILTO may
> change the recipient. The default from address remains unchanged.
>
> MFC after: 1 week
>
> Modified:
> head/usr.sbin/cron/cron/cron.8
> head/usr.sbin/cron/cron/do_command.c
> head/usr.sbin/cron/crontab/crontab.5
>
Is this going to allow normal users to spoof the From: using private
crontabs? That sounds mildly dangerous.
-- Ian
> Modified: head/usr.sbin/cron/cron/cron.8
> =====================================================================
> =========
> --- head/usr.sbin/cron/cron/cron.8 Mon Apr 15 18:49:04 2019 (r346
> 251)
> +++ head/usr.sbin/cron/cron/cron.8 Mon Apr 15 18:53:28 2019 (r346
> 252)
> @@ -17,7 +17,7 @@
> .\"
> .\" $FreeBSD$
> .\"
> -.Dd July 19, 2017
> +.Dd April 15, 2019
> .Dt CRON 8
> .Os
> .Sh NAME
> @@ -79,6 +79,9 @@ commands, any output is mailed to the owner of the
> cro
> named in the
> .Ev MAILTO
> environment variable in the crontab, if such exists).
> +The from address of this mail may be set with the
> +.Ev MAILFROM
> +environment variable.
> .Pp
> Additionally,
> .Nm
>
> Modified: head/usr.sbin/cron/cron/do_command.c
> =====================================================================
> =========
> --- head/usr.sbin/cron/cron/do_command.c Mon Apr 15 18:49:04
> 2019 (r346251)
> +++ head/usr.sbin/cron/cron/do_command.c Mon Apr 15 18:53:28
> 2019 (r346252)
> @@ -93,7 +93,7 @@ child_process(e, u)
> {
> int stdin_pipe[2], stdout_pipe[2];
> register char *input_data;
> - char *usernm, *mailto;
> + char *usernm, *mailto, *mailfrom;
> int children = 0;
> # if defined(LOGIN_CAP)
> struct passwd *pwd;
> @@ -111,6 +111,7 @@ child_process(e, u)
> */
> usernm = env_get("LOGNAME", e->envp);
> mailto = env_get("MAILTO", e->envp);
> + mailfrom = env_get("MAILFROM", e->envp);
>
> #ifdef PAM
> /* use PAM to see if the user's account is available,
> @@ -503,8 +504,12 @@ child_process(e, u)
> warn("%s", MAILCMD);
> (void) _exit(ERROR_EXIT);
> }
> - fprintf(mail, "From: Cron Daemon
> <%s@%s>\n",
> - usernm, hostname);
> + if (mailfrom == NULL || *mailfrom ==
> '\0')
> + fprintf(mail, "From: Cron
> Daemon <%s@%s>\n",
> + usernm, hostname);
> + else
> + fprintf(mail, "From: Cron
> Daemon <%s>\n",
> + mailfrom);
> fprintf(mail, "To: %s\n", mailto);
> fprintf(mail, "Subject: Cron <%s@%s>
> %s\n",
> usernm, first_word(hostname,
> "."),
>
> Modified: head/usr.sbin/cron/crontab/crontab.5
> =====================================================================
> =========
> --- head/usr.sbin/cron/crontab/crontab.5 Mon Apr 15 18:49:04
> 2019 (r346251)
> +++ head/usr.sbin/cron/crontab/crontab.5 Mon Apr 15 18:53:28
> 2019 (r346252)
> @@ -17,7 +17,7 @@
> .\"
> .\" $FreeBSD$
> .\"
> -.Dd June 6, 2018
> +.Dd April 15, 2019
> .Dt CRONTAB 5
> .Os
> .Sh NAME
> @@ -116,6 +116,9 @@ If
> .Ev MAILTO
> is defined (and non-empty), mail is
> sent to the user so named.
> +If
> +.Ev MAILFROM
> +is defined (and non-empty), its value will be used as the from
> address.
> .Ev MAILTO
> may also be used to direct mail to multiple recipients
> by separating recipient users with a comma.
>
More information about the svn-src-all
mailing list