summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Nikias Bassen2010-06-04 13:26:05 +0200
committerGravatar Nikias Bassen2010-06-04 13:26:05 +0200
commit837d5b0f5a401389802bddb468372a9bcbd418a0 (patch)
treed6a1398ed86e74a13f127dcffc0628e5b20aee02
parentfadef8f4ee9e986eeb87de11d752a14c63974f3b (diff)
downloadlibimobiledevice-837d5b0f5a401389802bddb468372a9bcbd418a0.tar.gz
libimobiledevice-837d5b0f5a401389802bddb468372a9bcbd418a0.tar.bz2
idevicebackup: verify Info.plist to ensure restoring to same device
-rw-r--r--tools/idevicebackup.c12
1 files changed, 11 insertions, 1 deletions
diff --git a/tools/idevicebackup.c b/tools/idevicebackup.c
index 04e633e..2018bc6 100644
--- a/tools/idevicebackup.c
+++ b/tools/idevicebackup.c
@@ -602,9 +602,19 @@ int main(int argc, char *argv[])
printf("Aborting backup. Backup is not compatible with the current device.\n");
cmd = CMD_LEAVE;
}
+ } else if (info_plist && (cmd == CMD_RESTORE)) {
+ if (!mobilebackup_info_is_current_device(info_plist)) {
+ printf("Aborting restore. Backup data is not compatible with the current device.\n");
+ cmd = CMD_LEAVE;
+ }
}
} else {
- is_full_backup = 1;
+ if (cmd == CMD_RESTORE) {
+ printf("Aborting restore. Info.plist is missing.\n");
+ cmd = CMD_LEAVE;
+ } else {
+ is_full_backup = 1;
+ }
}
uint64_t lockfile = 0;