From 85defcf0e9e4187107b8a1a5138ef9590ac3892c Mon Sep 17 00:00:00 2001 From: Phil Pennock Date: Tue, 15 May 2018 19:04:34 -0400 Subject: Don't open spool data-files which are symlinks --- src/src/spool_in.c | 8 ++++++++ 1 file changed, 8 insertions(+) (limited to 'src') diff --git a/src/src/spool_in.c b/src/src/spool_in.c index 33890c516..cd74d1ee7 100644 --- a/src/src/spool_in.c +++ b/src/src/spool_in.c @@ -57,9 +57,17 @@ for (i = 0; i < 2; i++) fname = spool_fname(US"input", message_subdir, id, US"-D"); DEBUG(D_deliver) debug_printf("Trying spool file %s\n", fname); + /* We protect against symlink attacks both in not propagating the + * file-descriptor to other processes as we exec, and also ensuring that we + * don't even open symlinks. + * No -D file inside the spool area should be a symlink. + */ if ((fd = Uopen(fname, #ifdef O_CLOEXEC O_CLOEXEC | +#endif +#ifdef O_NOFOLLOW + O_NOFOLLOW | #endif O_RDWR | O_APPEND, 0)) >= 0) break; -- cgit v1.2.3