aboutsummaryrefslogtreecommitdiffstats
path: root/apps/dav/lib/UserMigration
diff options
context:
space:
mode:
authorChristopher Ng <chrng8@gmail.com>2022-03-09 18:58:23 +0000
committerChristopher Ng <chrng8@gmail.com>2022-03-09 19:46:37 +0000
commite97701c6b0509de26dbad86d0d3569be331cb94b (patch)
tree8ad93710b20decd2a93a425f2897e5679f3c2bc1 /apps/dav/lib/UserMigration
parent0cbb6d7ba9b5d3b2c79f2cf0bafe6145da0857f6 (diff)
downloadnextcloud-server-e97701c6b0509de26dbad86d0d3569be331cb94b.tar.gz
nextcloud-server-e97701c6b0509de26dbad86d0d3569be331cb94b.zip
Improve error handling and output messages
Signed-off-by: Christopher Ng <chrng8@gmail.com>
Diffstat (limited to 'apps/dav/lib/UserMigration')
-rw-r--r--apps/dav/lib/UserMigration/CalendarMigrator.php35
1 files changed, 22 insertions, 13 deletions
diff --git a/apps/dav/lib/UserMigration/CalendarMigrator.php b/apps/dav/lib/UserMigration/CalendarMigrator.php
index bc5cfe35218..d0d9e94351b 100644
--- a/apps/dav/lib/UserMigration/CalendarMigrator.php
+++ b/apps/dav/lib/UserMigration/CalendarMigrator.php
@@ -106,13 +106,13 @@ class CalendarMigrator implements IMigrator {
* @throws CalendarMigratorException
* @throws InvalidCalendarException
*/
- private function getCalendarExportData(IUser $user, ICalendar $calendar): array {
+ private function getCalendarExportData(IUser $user, ICalendar $calendar, OutputInterface $output): array {
$userId = $user->getUID();
$calendarId = $calendar->getKey();
$calendarInfo = $this->calDavBackend->getCalendarById($calendarId);
if (empty($calendarInfo)) {
- throw new CalendarMigratorException("Invalid info for calendar ID: $calendarId");
+ throw new CalendarMigratorException("Invalid info for calendar ID $calendarId");
}
$uri = $calendarInfo['uri'];
@@ -155,6 +155,12 @@ class CalendarMigrator implements IMigrator {
$blobs,
);
+ $problems = $mergedCalendar->validate();
+ if (!empty($problems)) {
+ $output->writeln('Skipping calendar "' . $properties['{DAV:}displayname'] . '" containing invalid calendar data');
+ throw new InvalidCalendarException();
+ }
+
return [
'name' => $calendarNode->getName(),
'vCalendar' => $mergedCalendar,
@@ -166,13 +172,13 @@ class CalendarMigrator implements IMigrator {
*
* @throws CalendarMigratorException
*/
- private function getCalendarExports(IUser $user): array {
+ private function getCalendarExports(IUser $user, OutputInterface $output): array {
$principalUri = $this->getPrincipalUri($user);
return array_values(array_filter(array_map(
- function (ICalendar $calendar) use ($user) {
+ function (ICalendar $calendar) use ($user, $output) {
try {
- return $this->getCalendarExportData($user, $calendar);
+ return $this->getCalendarExportData($user, $calendar, $output);
} catch (InvalidCalendarException $e) {
// Allow this exception as invalid (e.g. deleted) calendars are not to be exported
return null;
@@ -213,12 +219,10 @@ class CalendarMigrator implements IMigrator {
public function export(IUser $user, IExportDestination $exportDestination, OutputInterface $output): void {
$output->writeln('Exporting calendars into ' . CalendarMigrator::EXPORT_ROOT . '…');
- $userId = $user->getUID();
-
- $calendarExports = $this->getCalendarExports($user);
+ $calendarExports = $this->getCalendarExports($user, $output);
if (empty($calendarExports)) {
- $output->writeln("User <$userId> has no calendars to export");
+ $output->writeln('No calendars to export…');
}
/**
@@ -414,7 +418,12 @@ class CalendarMigrator implements IMigrator {
$output->writeln('Importing calendars from ' . CalendarMigrator::EXPORT_ROOT . '…');
- foreach ($importSource->getFolderListing(CalendarMigrator::EXPORT_ROOT) as $filename) {
+ $calendarImports = $importSource->getFolderListing(CalendarMigrator::EXPORT_ROOT);
+ if (empty($calendarImports)) {
+ $output->writeln('No calendars to import…');
+ }
+
+ foreach ($calendarImports as $filename) {
$importPath = CalendarMigrator::EXPORT_ROOT . $filename;
try {
/** @var VCalendar $vCalendar */
@@ -423,17 +432,17 @@ class CalendarMigrator implements IMigrator {
VObjectReader::OPTION_FORGIVING,
);
} catch (Throwable $e) {
- throw new CalendarMigratorException("Failed to read file: \"$importPath\"", 0, $e);
+ throw new CalendarMigratorException("Failed to read file \"$importPath\"", 0, $e);
}
$problems = $vCalendar->validate();
if (!empty($problems)) {
- throw new CalendarMigratorException("Invalid calendar data contained in: \"$importPath\"");
+ throw new CalendarMigratorException("Invalid calendar data contained in \"$importPath\"");
}
$splitFilename = explode('_', $filename, 2);
if (count($splitFilename) !== 2) {
- throw new CalendarMigratorException("Invalid filename: \"$filename\", expected filename of the format: \"<calendar_name>_YYYY-MM-DD" . CalendarMigrator::FILENAME_EXT . '"');
+ throw new CalendarMigratorException("Invalid filename \"$filename\", expected filename of the format \"<calendar_name>_YYYY-MM-DD" . CalendarMigrator::FILENAME_EXT . '"');
}
[$initialCalendarUri, $suffix] = $splitFilename;