mirror of
https://github.com/nextcloud/server.git
synced 2026-04-27 01:00:20 -04:00
Skip instead of throwing on invalid calendar migration
Signed-off-by: Christopher Ng <chrng8@gmail.com>
This commit is contained in:
parent
fa773ece6d
commit
07bf129809
1 changed files with 10 additions and 4 deletions
|
|
@ -182,6 +182,9 @@ class CalendarMigrator implements IMigrator, ISizeEstimationMigrator {
|
|||
)));
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws InvalidCalendarException
|
||||
*/
|
||||
private function getUniqueCalendarUri(IUser $user, string $initialCalendarUri): string {
|
||||
$principalUri = $this->getPrincipalUri($user);
|
||||
|
||||
|
|
@ -190,7 +193,7 @@ class CalendarMigrator implements IMigrator, ISizeEstimationMigrator {
|
|||
: CalendarMigrator::MIGRATED_URI_PREFIX . $initialCalendarUri;
|
||||
|
||||
if ($initialCalendarUri === '') {
|
||||
throw new CalendarMigratorException('Failed to get unique calendar URI');
|
||||
throw new InvalidCalendarException();
|
||||
}
|
||||
|
||||
$existingCalendarUris = array_map(
|
||||
|
|
@ -457,17 +460,20 @@ class CalendarMigrator implements IMigrator, ISizeEstimationMigrator {
|
|||
VObjectReader::OPTION_FORGIVING,
|
||||
);
|
||||
} catch (Throwable $e) {
|
||||
throw new CalendarMigratorException("Failed to read file \"$importPath\"", 0, $e);
|
||||
$output->writeln("Failed to read file \"$importPath\", skipping…");
|
||||
continue;
|
||||
}
|
||||
|
||||
$problems = $vCalendar->validate();
|
||||
if (!empty($problems)) {
|
||||
throw new CalendarMigratorException("Invalid calendar data contained in \"$importPath\"");
|
||||
$output->writeln("Invalid calendar data contained in \"$importPath\", skipping…");
|
||||
continue;
|
||||
}
|
||||
|
||||
$splitFilename = explode('.', $filename, 2);
|
||||
if (count($splitFilename) !== 2) {
|
||||
throw new CalendarMigratorException("Invalid filename \"$filename\", expected filename of the format \"<calendar_name>" . CalendarMigrator::FILENAME_EXT . '"');
|
||||
$output->writeln("Invalid filename \"$filename\", expected filename of the format \"<calendar_name>" . CalendarMigrator::FILENAME_EXT . '", skipping…');
|
||||
continue;
|
||||
}
|
||||
[$initialCalendarUri, $ext] = $splitFilename;
|
||||
|
||||
|
|
|
|||
Loading…
Reference in a new issue