Commit ddd6ce5c authored by owsla's avatar owsla

Suppress traceback if permission error during restore


git-svn-id: http://svn.savannah.nongnu.org/svn/rdiff-backup@1043 2b77aa54-bcbc-44c9-a7ec-4f6cf2b41109
parent bd17bd79
New in v1.2.8 (????/??/??) New in v1.2.8 (????/??/??)
--------------------------- ---------------------------
Improve handling of incorrect permissions on backup repository during restore
operation. Closes Ubuntu bug #329722. (Andrew Ferguson)
Don't crash on zlib errors. Closes Debian bug #518531. (Andrew Ferguson) Don't crash on zlib errors. Closes Debian bug #518531. (Andrew Ferguson)
Make sticky bit warnings quieter while determining file system abilities. Make sticky bit warnings quieter while determining file system abilities.
......
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
"""Start (and end) here - read arguments, set global settings, etc.""" """Start (and end) here - read arguments, set global settings, etc."""
from __future__ import generators from __future__ import generators
import getopt, sys, re, os, cStringIO, tempfile import getopt, sys, re, os, cStringIO, tempfile, errno
from log import Log, LoggerError, ErrorLog from log import Log, LoggerError, ErrorLog
import Globals, Time, SetConnections, selection, robust, rpath, \ import Globals, Time, SetConnections, selection, robust, rpath, \
manage, backup, connection, restore, FilenameMapping, \ manage, backup, connection, restore, FilenameMapping, \
...@@ -426,8 +426,12 @@ def backup_set_rbdir(rpin, rpout): ...@@ -426,8 +426,12 @@ def backup_set_rbdir(rpin, rpout):
global incdir global incdir
try: try:
incdir = Globals.rbdir.append_path("increments") incdir = Globals.rbdir.append_path("increments")
except (OSError, IOError), exc: except IOError, exc:
Log.FatalError("Could not begin backup due to\n%s" % exc) if exc.errno == errno.EACCES:
print "\n"
Log.FatalError("Could not begin backup due to\n%s" % exc)
else:
raise
assert rpout.lstat(), (rpout.path, rpout.lstat()) assert rpout.lstat(), (rpout.path, rpout.lstat())
if rpout.isdir() and not rpout.listdir(): # rpout is empty dir if rpout.isdir() and not rpout.listdir(): # rpout is empty dir
...@@ -548,9 +552,12 @@ def Restore(src_rp, dest_rp, restore_as_of = None): ...@@ -548,9 +552,12 @@ def Restore(src_rp, dest_rp, restore_as_of = None):
restore_check_paths(src_rp, dest_rp, restore_as_of) restore_check_paths(src_rp, dest_rp, restore_as_of)
try: try:
dest_rp.conn.fs_abilities.restore_set_globals(dest_rp) dest_rp.conn.fs_abilities.restore_set_globals(dest_rp)
except (OSError, IOError), exc: except IOError, exc:
print "\n" if exc.errno == errno.EACCES:
Log.FatalError("Could not begin restore due to\n%s" % exc) print "\n"
Log.FatalError("Could not begin restore due to\n%s" % exc)
else:
raise
init_user_group_mapping(dest_rp.conn) init_user_group_mapping(dest_rp.conn)
src_rp = restore_init_quoting(src_rp) src_rp = restore_init_quoting(src_rp)
restore_check_backup_dir(restore_root, src_rp, restore_as_of) restore_check_backup_dir(restore_root, src_rp, restore_as_of)
...@@ -561,9 +568,17 @@ def Restore(src_rp, dest_rp, restore_as_of = None): ...@@ -561,9 +568,17 @@ def Restore(src_rp, dest_rp, restore_as_of = None):
else: time = src_rp.getinctime() else: time = src_rp.getinctime()
restore_set_select(restore_root, dest_rp) restore_set_select(restore_root, dest_rp)
restore_start_log(src_rp, dest_rp, time) restore_start_log(src_rp, dest_rp, time)
restore.Restore(restore_root.new_index(restore_index), try:
inc_rpath, dest_rp, time) restore.Restore(restore_root.new_index(restore_index),
Log("Restore finished", 4) inc_rpath, dest_rp, time)
except IOError, exc:
if exc.errno == errno.EACCES:
print "\n"
Log.FatalError("Could not complete restore due to\n%s" % exc)
else:
raise
else:
Log("Restore finished", 4)
def restore_init_quoting(src_rp): def restore_init_quoting(src_rp):
"""Change rpaths into quoted versions of themselves if necessary""" """Change rpaths into quoted versions of themselves if necessary"""
......
New in v1.3.3 (????/??/??) New in v1.3.3 (????/??/??)
--------------------------- ---------------------------
Improve handling of incorrect permissions on backup repository during restore
operation. Closes Ubuntu bug #329722. (Andrew Ferguson)
Don't crash on zlib errors. Closes Debian bug #518531. (Andrew Ferguson) Don't crash on zlib errors. Closes Debian bug #518531. (Andrew Ferguson)
Make sticky bit warnings quieter while determining file system abilities. Make sticky bit warnings quieter while determining file system abilities.
......
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
"""Start (and end) here - read arguments, set global settings, etc.""" """Start (and end) here - read arguments, set global settings, etc."""
from __future__ import generators from __future__ import generators
import getopt, sys, re, os, cStringIO, tempfile, time import getopt, sys, re, os, cStringIO, tempfile, time, errno
from log import Log, LoggerError, ErrorLog from log import Log, LoggerError, ErrorLog
import Globals, Time, SetConnections, selection, robust, rpath, \ import Globals, Time, SetConnections, selection, robust, rpath, \
manage, backup, connection, restore, FilenameMapping, \ manage, backup, connection, restore, FilenameMapping, \
...@@ -429,8 +429,12 @@ def backup_set_rbdir(rpin, rpout): ...@@ -429,8 +429,12 @@ def backup_set_rbdir(rpin, rpout):
global incdir global incdir
try: try:
incdir = Globals.rbdir.append_path("increments") incdir = Globals.rbdir.append_path("increments")
except (OSError, IOError), exc: except IOError, exc:
Log.FatalError("Could not begin backup due to\n%s" % exc) if exc.errno == errno.EACCES:
print "\n"
Log.FatalError("Could not begin backup due to\n%s" % exc)
else:
raise
assert rpout.lstat(), (rpout.path, rpout.lstat()) assert rpout.lstat(), (rpout.path, rpout.lstat())
if rpout.isdir() and not rpout.listdir(): # rpout is empty dir if rpout.isdir() and not rpout.listdir(): # rpout is empty dir
...@@ -564,9 +568,12 @@ def Restore(src_rp, dest_rp, restore_as_of = None): ...@@ -564,9 +568,12 @@ def Restore(src_rp, dest_rp, restore_as_of = None):
restore_check_paths(src_rp, dest_rp, restore_as_of) restore_check_paths(src_rp, dest_rp, restore_as_of)
try: try:
dest_rp.conn.fs_abilities.restore_set_globals(dest_rp) dest_rp.conn.fs_abilities.restore_set_globals(dest_rp)
except (OSError, IOError), exc: except IOError, exc:
print "\n" if exc.errno == errno.EACCES:
Log.FatalError("Could not begin restore due to\n%s" % exc) print "\n"
Log.FatalError("Could not begin restore due to\n%s" % exc)
else:
raise
init_user_group_mapping(dest_rp.conn) init_user_group_mapping(dest_rp.conn)
src_rp = restore_init_quoting(src_rp) src_rp = restore_init_quoting(src_rp)
restore_check_backup_dir(restore_root, src_rp, restore_as_of) restore_check_backup_dir(restore_root, src_rp, restore_as_of)
...@@ -577,9 +584,17 @@ def Restore(src_rp, dest_rp, restore_as_of = None): ...@@ -577,9 +584,17 @@ def Restore(src_rp, dest_rp, restore_as_of = None):
else: time = src_rp.getinctime() else: time = src_rp.getinctime()
restore_set_select(restore_root, dest_rp) restore_set_select(restore_root, dest_rp)
restore_start_log(src_rp, dest_rp, time) restore_start_log(src_rp, dest_rp, time)
restore.Restore(restore_root.new_index(restore_index), try:
inc_rpath, dest_rp, time) restore.Restore(restore_root.new_index(restore_index),
Log("Restore finished", 4) inc_rpath, dest_rp, time)
except IOError, exc:
if exc.errno == errno.EACCES:
print "\n"
Log.FatalError("Could not complete restore due to\n%s" % exc)
else:
raise
else:
Log("Restore finished", 4)
def restore_init_quoting(src_rp): def restore_init_quoting(src_rp):
"""Change rpaths into quoted versions of themselves if necessary""" """Change rpaths into quoted versions of themselves if necessary"""
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment