2015-09-11 17:37:14 +02:00
|
|
|
---
|
|
|
|
Makefile.am | 4 -
|
|
|
|
Makefile.in | 6 +-
|
2016-07-26 14:55:44 +02:00
|
|
|
lib.c | 15 ++++---
|
2015-09-11 17:37:14 +02:00
|
|
|
mbox.c | 2
|
|
|
|
mh.c | 9 +++-
|
|
|
|
mutt.h | 1
|
|
|
|
opennfs.c | 122 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
|
|
|
sendlib.c | 2
|
2016-07-26 14:55:44 +02:00
|
|
|
8 files changed, 148 insertions(+), 13 deletions(-)
|
2015-09-11 17:37:14 +02:00
|
|
|
|
2009-11-25 16:10:30 +01:00
|
|
|
--- Makefile.am
|
2016-09-13 13:00:11 +02:00
|
|
|
+++ Makefile.am 2016-09-13 09:59:28.591766504 +0000
|
|
|
|
@@ -28,7 +28,7 @@ mutt_SOURCES = \
|
2007-01-16 00:26:03 +01:00
|
|
|
edit.c enter.c flags.c init.c filter.c from.c \
|
|
|
|
getdomain.c group.c \
|
|
|
|
handler.c hash.c hdrline.c headers.c help.c hook.c keymap.c \
|
|
|
|
- main.c mbox.c menu.c mh.c mx.c pager.c parse.c pattern.c \
|
|
|
|
+ main.c mbox.c menu.c mh.c mx.c opennfs.c pager.c parse.c pattern.c \
|
|
|
|
postpone.c query.c recvattach.c recvcmd.c \
|
2007-06-03 21:54:37 +02:00
|
|
|
rfc822.c rfc1524.c rfc2047.c rfc2231.c rfc3676.c \
|
2016-05-12 16:10:16 +02:00
|
|
|
score.c send.c sendlib.c signal.c sort.c \
|
2016-09-13 13:00:11 +02:00
|
|
|
@@ -93,7 +93,7 @@ mutt_dotlock_SOURCES = mutt_dotlock.c
|
2015-09-11 17:37:14 +02:00
|
|
|
mutt_dotlock_LDADD = $(LIBOBJS)
|
|
|
|
mutt_dotlock_DEPENDENCIES = $(LIBOBJS)
|
2007-01-16 00:26:03 +01:00
|
|
|
|
2007-12-21 10:26:06 +01:00
|
|
|
-pgpring_SOURCES = pgppubring.c pgplib.c lib.c extlib.c sha1.c md5.c pgppacket.c ascii.c
|
|
|
|
+pgpring_SOURCES = pgppubring.c pgplib.c lib.c extlib.c sha1.c opennfs.c md5.c pgppacket.c ascii.c
|
2015-09-11 17:37:14 +02:00
|
|
|
pgpring_LDADD = $(LIBOBJS) $(INTLLIBS)
|
|
|
|
pgpring_DEPENDENCIES = $(LIBOBJS) $(INTLDEPS)
|
2007-01-16 00:26:03 +01:00
|
|
|
|
2009-11-25 16:10:30 +01:00
|
|
|
--- Makefile.in
|
2016-09-13 13:00:11 +02:00
|
|
|
+++ Makefile.in 2016-09-13 09:59:28.591766504 +0000
|
2016-05-31 14:38:26 +02:00
|
|
|
@@ -125,7 +125,7 @@ am_mutt_OBJECTS = addrbook.$(OBJEXT) ali
|
2009-03-03 22:28:29 +01:00
|
|
|
hash.$(OBJEXT) hdrline.$(OBJEXT) headers.$(OBJEXT) \
|
|
|
|
help.$(OBJEXT) hook.$(OBJEXT) keymap.$(OBJEXT) main.$(OBJEXT) \
|
|
|
|
mbox.$(OBJEXT) menu.$(OBJEXT) mh.$(OBJEXT) mx.$(OBJEXT) \
|
|
|
|
- pager.$(OBJEXT) parse.$(OBJEXT) pattern.$(OBJEXT) \
|
|
|
|
+ opennfs.$(OBJEXT) pager.$(OBJEXT) parse.$(OBJEXT) pattern.$(OBJEXT) \
|
|
|
|
postpone.$(OBJEXT) query.$(OBJEXT) recvattach.$(OBJEXT) \
|
|
|
|
recvcmd.$(OBJEXT) rfc822.$(OBJEXT) rfc1524.$(OBJEXT) \
|
|
|
|
rfc2047.$(OBJEXT) rfc2231.$(OBJEXT) rfc3676.$(OBJEXT) \
|
2016-05-31 14:38:26 +02:00
|
|
|
@@ -154,7 +154,7 @@ pgpewrap_LDADD = $(LDADD)
|
2015-09-11 17:37:14 +02:00
|
|
|
pgpewrap_DEPENDENCIES = $(LIBOBJS) $(am__DEPENDENCIES_1)
|
2007-01-16 00:26:03 +01:00
|
|
|
am_pgpring_OBJECTS = pgppubring.$(OBJEXT) pgplib.$(OBJEXT) \
|
2007-12-21 10:26:06 +01:00
|
|
|
lib.$(OBJEXT) extlib.$(OBJEXT) sha1.$(OBJEXT) md5.$(OBJEXT) \
|
2007-01-16 00:26:03 +01:00
|
|
|
- pgppacket.$(OBJEXT) ascii.$(OBJEXT)
|
|
|
|
+ pgppacket.$(OBJEXT) ascii.$(OBJEXT) opennfs.$(OBJEXT)
|
|
|
|
pgpring_OBJECTS = $(am_pgpring_OBJECTS)
|
2015-09-11 17:37:14 +02:00
|
|
|
am_txt2c_OBJECTS = txt2c.$(OBJEXT)
|
|
|
|
txt2c_OBJECTS = $(am_txt2c_OBJECTS)
|
2016-05-31 14:38:26 +02:00
|
|
|
@@ -481,7 +481,7 @@ mutt_SOURCES = \
|
2007-01-16 00:26:03 +01:00
|
|
|
edit.c enter.c flags.c init.c filter.c from.c \
|
|
|
|
getdomain.c group.c \
|
|
|
|
handler.c hash.c hdrline.c headers.c help.c hook.c keymap.c \
|
|
|
|
- main.c mbox.c menu.c mh.c mx.c pager.c parse.c pattern.c \
|
|
|
|
+ main.c mbox.c menu.c mh.c mx.c opennfs.c pager.c parse.c pattern.c \
|
|
|
|
postpone.c query.c recvattach.c recvcmd.c \
|
2007-06-03 21:54:37 +02:00
|
|
|
rfc822.c rfc1524.c rfc2047.c rfc2231.c rfc3676.c \
|
2007-01-16 00:26:03 +01:00
|
|
|
score.c send.c sendlib.c signal.c sort.c \
|
2009-11-25 16:10:30 +01:00
|
|
|
--- lib.c
|
2016-09-13 13:00:11 +02:00
|
|
|
+++ lib.c 2016-09-13 09:59:28.591766504 +0000
|
2009-03-03 22:28:29 +01:00
|
|
|
@@ -50,6 +50,7 @@
|
2007-01-16 00:26:03 +01:00
|
|
|
#define EX_OK 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
+#include "mutt.h"
|
|
|
|
#include "lib.h"
|
|
|
|
|
2007-06-03 21:54:37 +02:00
|
|
|
|
2016-07-26 14:55:44 +02:00
|
|
|
@@ -545,7 +546,7 @@ int safe_rename (const char *src, const
|
|
|
|
|
|
|
|
|
|
|
|
/* Create a temporary directory next to a file name */
|
|
|
|
-
|
|
|
|
+#if defined(__linux__)
|
|
|
|
static int mutt_mkwrapdir (const char *path, char *newfile, size_t nflen,
|
|
|
|
char *newdir, size_t ndlen)
|
|
|
|
{
|
|
|
|
@@ -581,7 +582,7 @@ static int mutt_mkwrapdir (const char *p
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
-
|
|
|
|
+#endif
|
|
|
|
/* remove a directory and everything under it */
|
|
|
|
int mutt_rmtree (const char* path)
|
|
|
|
{
|
|
|
|
@@ -621,7 +622,7 @@ int mutt_rmtree (const char* path)
|
|
|
|
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
-
|
|
|
|
+#if defined(__linux__)
|
|
|
|
static int mutt_put_file_in_place (const char *path, const char *safe_file, const char *safe_dir)
|
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
@@ -631,12 +632,16 @@ static int mutt_put_file_in_place (const
|
|
|
|
rmdir (safe_dir);
|
|
|
|
return rv;
|
|
|
|
}
|
|
|
|
-
|
|
|
|
+#endif
|
|
|
|
int safe_open (const char *path, int flags)
|
|
|
|
{
|
2007-01-16 00:26:03 +01:00
|
|
|
struct stat osb, nsb;
|
|
|
|
int fd;
|
|
|
|
|
2007-06-03 21:54:37 +02:00
|
|
|
+#if defined(__linux__)
|
2007-01-16 00:26:03 +01:00
|
|
|
+ if ((fd = opennfs (path, flags, 0600)) < 0)
|
2007-06-03 21:54:37 +02:00
|
|
|
+ return fd;
|
|
|
|
+#else
|
|
|
|
if (flags & O_EXCL)
|
|
|
|
{
|
|
|
|
char safe_file[_POSIX_PATH_MAX];
|
2016-05-12 16:10:16 +02:00
|
|
|
@@ -660,7 +665,7 @@ int safe_open (const char *path, int fla
|
2007-01-16 00:26:03 +01:00
|
|
|
|
2007-06-03 21:54:37 +02:00
|
|
|
if ((fd = open (path, flags & ~O_EXCL, 0600)) < 0)
|
|
|
|
return fd;
|
|
|
|
-
|
|
|
|
+#endif
|
2007-01-16 00:26:03 +01:00
|
|
|
/* make sure the file is not symlink */
|
2007-06-03 21:54:37 +02:00
|
|
|
if (lstat (path, &osb) < 0 || fstat (fd, &nsb) < 0 ||
|
|
|
|
compare_stat(&osb, &nsb) == -1)
|
2009-11-25 16:10:30 +01:00
|
|
|
--- mbox.c
|
2016-09-13 13:00:11 +02:00
|
|
|
+++ mbox.c 2016-09-13 09:59:28.591766504 +0000
|
2016-07-26 14:55:44 +02:00
|
|
|
@@ -781,7 +781,7 @@ int mbox_sync_mailbox (CONTEXT *ctx, int
|
2007-01-16 00:26:03 +01:00
|
|
|
|
|
|
|
/* Create a temporary file to write the new version of the mailbox in. */
|
2010-11-10 09:48:26 +01:00
|
|
|
mutt_mktemp (tempfile, sizeof (tempfile));
|
2007-01-16 00:26:03 +01:00
|
|
|
- if ((i = open (tempfile, O_WRONLY | O_EXCL | O_CREAT, 0600)) == -1 ||
|
|
|
|
+ if ((i = opennfs (tempfile, O_WRONLY | O_EXCL | O_CREAT, 0600)) == -1 ||
|
|
|
|
(fp = fdopen (i, "w")) == NULL)
|
|
|
|
{
|
|
|
|
if (-1 != i)
|
2009-11-25 16:10:30 +01:00
|
|
|
--- mh.c
|
2016-09-13 13:00:11 +02:00
|
|
|
+++ mh.c 2016-09-13 09:59:28.591766504 +0000
|
2016-07-26 14:55:44 +02:00
|
|
|
@@ -358,7 +358,11 @@ static int mh_mkstemp (CONTEXT * dest, F
|
2007-01-16 00:26:03 +01:00
|
|
|
{
|
2016-05-12 16:10:16 +02:00
|
|
|
snprintf (path, _POSIX_PATH_MAX, "%s/.mutt-%s-%d-%" PRIu64,
|
|
|
|
dest->path, NONULL (Hostname), (int) getpid (), mutt_rand64());
|
2007-06-03 21:54:37 +02:00
|
|
|
+#if defined(__linux__)
|
2007-01-16 00:26:03 +01:00
|
|
|
+ if ((fd = opennfs (path, O_WRONLY | O_EXCL | O_CREAT, 0600)) == -1)
|
2007-06-03 21:54:37 +02:00
|
|
|
+#else
|
|
|
|
if ((fd = open (path, O_WRONLY | O_EXCL | O_CREAT, 0666)) == -1)
|
|
|
|
+#endif
|
2007-01-16 00:26:03 +01:00
|
|
|
{
|
|
|
|
if (errno != EEXIST)
|
|
|
|
{
|
2016-07-26 14:55:44 +02:00
|
|
|
@@ -1382,8 +1386,11 @@ int maildir_open_new_message (MESSAGE *
|
2007-06-03 21:54:37 +02:00
|
|
|
|
2007-01-16 00:26:03 +01:00
|
|
|
dprint (2, (debugfile, "maildir_open_new_message (): Trying %s.\n",
|
|
|
|
path));
|
2007-06-03 21:54:37 +02:00
|
|
|
-
|
|
|
|
+#if defined(__linux__)
|
2007-01-16 00:26:03 +01:00
|
|
|
+ if ((fd = opennfs (path, O_WRONLY | O_EXCL | O_CREAT, 0600)) == -1)
|
2007-06-03 21:54:37 +02:00
|
|
|
+#else
|
|
|
|
if ((fd = open (path, O_WRONLY | O_EXCL | O_CREAT, 0666)) == -1)
|
|
|
|
+#endif
|
2007-01-16 00:26:03 +01:00
|
|
|
{
|
|
|
|
if (errno != EEXIST)
|
|
|
|
{
|
2009-11-25 16:10:30 +01:00
|
|
|
--- mutt.h
|
2016-09-13 13:00:11 +02:00
|
|
|
+++ mutt.h 2016-09-13 09:59:28.591766504 +0000
|
|
|
|
@@ -1076,4 +1076,5 @@ typedef struct
|
2007-01-16 00:26:03 +01:00
|
|
|
#include "lib.h"
|
|
|
|
#include "globals.h"
|
|
|
|
|
|
|
|
+extern int opennfs(const char *, int, int);
|
|
|
|
#endif /*MUTT_H*/
|
2009-11-25 16:10:30 +01:00
|
|
|
--- opennfs.c
|
2016-09-13 13:00:11 +02:00
|
|
|
+++ opennfs.c 2016-09-13 09:59:28.595766429 +0000
|
2007-01-16 00:26:03 +01:00
|
|
|
@@ -0,0 +1,122 @@
|
|
|
|
+#include <errno.h>
|
|
|
|
+#include <fcntl.h>
|
|
|
|
+#include <libgen.h>
|
|
|
|
+#include <limits.h>
|
|
|
|
+#include <nfs/nfs.h>
|
|
|
|
+#include <stdio.h>
|
|
|
|
+#include <stdlib.h>
|
|
|
|
+#include <string.h>
|
|
|
|
+#include <sys/types.h>
|
|
|
|
+#include <sys/stat.h>
|
|
|
|
+#include <sys/vfs.h>
|
|
|
|
+#include <unistd.h>
|
|
|
|
+
|
|
|
|
+#ifndef NFS_SUPER_MAGIC
|
|
|
|
+# define NFS_SUPER_MAGIC 0x6969
|
|
|
|
+#endif
|
|
|
|
+
|
|
|
|
+int opennfs(const char *path, int flags, int mode)
|
|
|
|
+{
|
|
|
|
+ char tmplock[NFS_MAXPATHLEN+1], sysname[256];
|
|
|
|
+ char *slash, *ptr, *dir, *base, *clear = (char*)0;
|
|
|
|
+ struct stat ps, ts;
|
|
|
|
+ struct statfs fs;
|
|
|
|
+ ssize_t len;
|
|
|
|
+ int ret;
|
|
|
|
+
|
|
|
|
+ if ((flags & (O_WRONLY|O_RDWR)) == 0)
|
|
|
|
+ goto safe;
|
|
|
|
+
|
|
|
|
+ if ((flags & (O_EXCL|O_CREAT)) != (O_EXCL|O_CREAT))
|
|
|
|
+ goto safe;
|
|
|
|
+
|
|
|
|
+#if defined(O_NOFOLLOW)
|
|
|
|
+ flags |= O_NOFOLLOW;
|
|
|
|
+#endif
|
|
|
|
+
|
|
|
|
+ ret = -1;
|
|
|
|
+ if ((clear = strdup(path)) == (char*)0)
|
|
|
|
+ goto err;
|
|
|
|
+ dir = dirname(clear);
|
|
|
|
+
|
|
|
|
+ if ((ret = (statfs(dir, &fs))) < 0)
|
|
|
|
+ goto err;
|
|
|
|
+
|
|
|
|
+ if (fs.f_type != NFS_SUPER_MAGIC)
|
|
|
|
+ goto safe;
|
|
|
|
+
|
|
|
|
+ if ((ret = gethostname(sysname, sizeof(sysname))) < 0)
|
|
|
|
+ goto err;
|
|
|
|
+
|
|
|
|
+ ret = -1;
|
|
|
|
+ ptr = &tmplock[0];
|
|
|
|
+ if (((len = snprintf(ptr, NFS_MAXPATHLEN, "%s/.%s-XXXXXX", dir, sysname)) < 0) || (len >= NFS_MAXPATHLEN))
|
|
|
|
+ goto err;
|
|
|
|
+ ptr += len;
|
|
|
|
+ slash = ptr;
|
|
|
|
+
|
|
|
|
+ free(clear);
|
|
|
|
+ clear = (char*)0;
|
|
|
|
+
|
|
|
|
+ if (mkdtemp(tmplock) == (char*)0)
|
|
|
|
+ goto err;
|
|
|
|
+
|
|
|
|
+ ret = -1;
|
|
|
|
+ if ((clear = strdup(path)) == (char*)0)
|
|
|
|
+ goto rmd;
|
|
|
|
+ base = basename(clear);
|
|
|
|
+
|
|
|
|
+ ret = -1;
|
|
|
|
+ if (((len = snprintf(ptr, NFS_MAXPATHLEN - len, "/%s", base)) < 0) || (len >= (NFS_MAXPATHLEN - len)))
|
|
|
|
+ goto rmd;
|
|
|
|
+
|
|
|
|
+ free(clear);
|
|
|
|
+ clear = (char*)0;
|
|
|
|
+
|
|
|
|
+ if ((ret = open(tmplock, flags, mode)) < 0)
|
|
|
|
+ goto rmd;
|
|
|
|
+
|
|
|
|
+ errno = 0;
|
|
|
|
+ do {
|
|
|
|
+ len = write(ret, "0", 2);
|
|
|
|
+ } while ((len < 0) && (errno == EINTR));
|
|
|
|
+ close(ret);
|
|
|
|
+
|
|
|
|
+ ret = -1;
|
|
|
|
+ errno = EBADF;
|
|
|
|
+ if (len != 2)
|
|
|
|
+ goto unl;
|
|
|
|
+
|
|
|
|
+ errno = 0;
|
|
|
|
+ if ((ret = lstat(tmplock, &ts)) < 0)
|
|
|
|
+ goto unl;
|
|
|
|
+
|
|
|
|
+ if (((ret = link(tmplock, path)) < 0) && (errno == EEXIST))
|
|
|
|
+ goto unl;
|
|
|
|
+
|
|
|
|
+ if ((ret = lstat(path, &ps)) < 0)
|
|
|
|
+ goto unl;
|
|
|
|
+
|
|
|
|
+ ret = -1;
|
|
|
|
+ errno = EEXIST;
|
|
|
|
+ if (ps.st_nlink != 2)
|
|
|
|
+ goto unl;
|
|
|
|
+ if ((ps.st_rdev != ts.st_rdev) || (ps.st_ino != ts.st_ino))
|
|
|
|
+ goto unl;
|
|
|
|
+
|
|
|
|
+ errno = 0;
|
|
|
|
+ flags |= O_TRUNC;
|
|
|
|
+ flags &= ~(O_EXCL|O_CREAT);
|
|
|
|
+ ret = open(path, flags, mode);
|
|
|
|
+unl:
|
|
|
|
+ unlink(tmplock);
|
|
|
|
+rmd:
|
|
|
|
+ *slash = '\0';
|
|
|
|
+ rmdir(tmplock);
|
|
|
|
+err:
|
|
|
|
+ if (clear) free(clear);
|
|
|
|
+ return ret;
|
|
|
|
+safe:
|
|
|
|
+ if (clear) free(clear);
|
|
|
|
+ return open(path, flags, mode);
|
|
|
|
+}
|
2009-11-25 16:10:30 +01:00
|
|
|
--- sendlib.c
|
2016-09-13 13:00:11 +02:00
|
|
|
+++ sendlib.c 2016-09-13 09:59:28.595766429 +0000
|
2016-05-31 14:38:26 +02:00
|
|
|
@@ -2260,7 +2260,7 @@ send_msg (const char *path, char **args,
|
2009-11-10 12:34:34 +01:00
|
|
|
if (SendmailWait >= 0 && tempfile && *tempfile)
|
2007-01-16 00:26:03 +01:00
|
|
|
{
|
|
|
|
/* *tempfile will be opened as stdout */
|
|
|
|
- if (open (*tempfile, O_WRONLY | O_APPEND | O_CREAT | O_EXCL, 0600) < 0)
|
|
|
|
+ if (opennfs (*tempfile, O_WRONLY | O_CREAT | O_EXCL, 0600) < 0)
|
|
|
|
_exit (S_ERR);
|
|
|
|
/* redirect stderr to *tempfile too */
|
|
|
|
if (dup (1) < 0)
|