[Patch #1514543] mailbox (Maildir): avoid losing messages on name clash
Two changes: Where possible, use link()/remove() to move files into a directory; this makes it easier to avoid overwriting an existing file. Use _create_carefully() to create files in tmp/, which uses O_EXCL. Backport candidate.
This commit is contained in:
parent
6fc2382883
commit
978d8286ae
|
@ -255,7 +255,19 @@ class Maildir(Mailbox):
|
|||
suffix = ''
|
||||
uniq = os.path.basename(tmp_file.name).split(self.colon)[0]
|
||||
dest = os.path.join(self._path, subdir, uniq + suffix)
|
||||
try:
|
||||
if hasattr(os, 'link'):
|
||||
os.link(tmp_file.name, dest)
|
||||
os.remove(tmp_file.name)
|
||||
else:
|
||||
os.rename(tmp_file.name, dest)
|
||||
except OSError, e:
|
||||
os.remove(tmp_file.name)
|
||||
if e.errno == errno.EEXIST:
|
||||
raise ExternalClashError('Name clash with existing message: %s'
|
||||
% dest)
|
||||
else:
|
||||
raise
|
||||
if isinstance(message, MaildirMessage):
|
||||
os.utime(dest, (os.path.getatime(dest), message.get_date()))
|
||||
return uniq
|
||||
|
@ -431,10 +443,15 @@ class Maildir(Mailbox):
|
|||
except OSError, e:
|
||||
if e.errno == errno.ENOENT:
|
||||
Maildir._count += 1
|
||||
return open(path, 'wb+')
|
||||
else:
|
||||
try:
|
||||
return _create_carefully(path)
|
||||
except OSError, e:
|
||||
if e.errno != errno.EEXIST:
|
||||
raise
|
||||
else:
|
||||
raise
|
||||
|
||||
# Fall through to here if stat succeeded or open raised EEXIST.
|
||||
raise ExternalClashError('Name clash prevented file creation: %s' %
|
||||
path)
|
||||
|
||||
|
|
|
@ -100,6 +100,10 @@ Library
|
|||
weren't passing the message factory on to newly created Maildir/MH
|
||||
objects.
|
||||
|
||||
- Patch #1514543: In the Maildir clash, report errors if there's
|
||||
a name clash instead of possibly losing a message. (Patch by David
|
||||
Watson.)
|
||||
|
||||
- Patch #1514544: Try to ensure that messages/indexes have been physically
|
||||
written to disk after calling .flush() or .close(). (Patch by David
|
||||
Watson.)
|
||||
|
|
Loading…
Reference in New Issue