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