xref: /openbsd/usr.sbin/smtpd/mda_mbox.c (revision d3140113)
1*d3140113Seric /*	$OpenBSD: mda_mbox.c,v 1.3 2021/06/14 17:58:15 eric Exp $	*/
22715edf2Sgilles 
32715edf2Sgilles /*
42715edf2Sgilles  * Copyright (c) 2018 Gilles Chehade <gilles@poolp.org>
52715edf2Sgilles  *
62715edf2Sgilles  * Permission to use, copy, modify, and distribute this software for any
72715edf2Sgilles  * purpose with or without fee is hereby granted, provided that the above
82715edf2Sgilles  * copyright notice and this permission notice appear in all copies.
92715edf2Sgilles  *
102715edf2Sgilles  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
112715edf2Sgilles  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
122715edf2Sgilles  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
132715edf2Sgilles  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
142715edf2Sgilles  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
152715edf2Sgilles  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
162715edf2Sgilles  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
172715edf2Sgilles  */
182715edf2Sgilles 
1968213f7bSgilles #include <sys/stat.h>
202715edf2Sgilles 
212715edf2Sgilles #include <err.h>
222715edf2Sgilles #include <errno.h>
2368213f7bSgilles #include <fcntl.h>
242715edf2Sgilles #include <paths.h>
252715edf2Sgilles #include <unistd.h>
262715edf2Sgilles 
272715edf2Sgilles #include "smtpd.h"
282715edf2Sgilles 
292715edf2Sgilles void
mda_mbox(struct deliver * deliver)302715edf2Sgilles mda_mbox(struct deliver *deliver)
312715edf2Sgilles {
322715edf2Sgilles 	int		ret;
332715edf2Sgilles 	char		sender[LINE_MAX];
342715edf2Sgilles 	char		*envp[] = {
352715edf2Sgilles 		"HOME=/",
362715edf2Sgilles 		"PATH=" _PATH_DEFPATH,
372715edf2Sgilles 		"LOGNAME=root",
382715edf2Sgilles 		"USER=root",
392715edf2Sgilles 		NULL,
402715edf2Sgilles 	};
412715edf2Sgilles 
422715edf2Sgilles 	if (deliver->sender.user[0] == '\0' &&
432715edf2Sgilles 	    deliver->sender.domain[0] == '\0')
442715edf2Sgilles 		ret = snprintf(sender, sizeof sender, "MAILER-DAEMON");
452715edf2Sgilles 	else
462715edf2Sgilles 		ret = snprintf(sender, sizeof sender, "%s@%s",
472715edf2Sgilles 			       deliver->sender.user, deliver->sender.domain);
482715edf2Sgilles 	if (ret < 0 || (size_t)ret >= sizeof sender)
4968213f7bSgilles 		errx(EX_TEMPFAIL, "sender address too long");
502715edf2Sgilles 
512715edf2Sgilles 	execle(PATH_MAILLOCAL, PATH_MAILLOCAL, "-f",
522715edf2Sgilles 	       sender, deliver->userinfo.username, (char *)NULL, envp);
532715edf2Sgilles 	perror("execl");
5468213f7bSgilles 	_exit(EX_TEMPFAIL);
5568213f7bSgilles }
5668213f7bSgilles 
5768213f7bSgilles void
mda_mbox_init(struct deliver * deliver)5868213f7bSgilles mda_mbox_init(struct deliver *deliver)
5968213f7bSgilles {
6068213f7bSgilles 	int	fd;
6168213f7bSgilles 	int	ret;
6268213f7bSgilles 	char	buffer[LINE_MAX];
6368213f7bSgilles 
6468213f7bSgilles 	ret = snprintf(buffer, sizeof buffer, "%s/%s",
6568213f7bSgilles 	    _PATH_MAILDIR, deliver->userinfo.username);
6668213f7bSgilles 	if (ret < 0 || (size_t)ret >= sizeof buffer)
6768213f7bSgilles 		errx(EX_TEMPFAIL, "mailbox pathname too long");
6868213f7bSgilles 
6968213f7bSgilles 	if ((fd = open(buffer, O_CREAT|O_EXCL, 0)) == -1) {
7068213f7bSgilles 		if (errno == EEXIST)
7168213f7bSgilles 			return;
7268213f7bSgilles 		err(EX_TEMPFAIL, "open");
7368213f7bSgilles 	}
7468213f7bSgilles 
7568213f7bSgilles 	if (fchown(fd, deliver->userinfo.uid, deliver->userinfo.gid) == -1)
7668213f7bSgilles 		err(EX_TEMPFAIL, "fchown");
7768213f7bSgilles 
7868213f7bSgilles 	if (fchmod(fd, S_IRUSR|S_IWUSR) == -1)
7968213f7bSgilles 		err(EX_TEMPFAIL, "fchown");
802715edf2Sgilles }
81