From cf93d7cdcc4aff22f92b0235dc492eeceff13ee7 Mon Sep 17 00:00:00 2001 From: Matthias Richter Date: Wed, 9 Oct 2024 19:46:09 +0200 Subject: [PATCH] Consider super works --- Classes/Command/HealthCheckCommand.php | 25 ++++++++++++++++++++++++- 1 file changed, 24 insertions(+), 1 deletion(-) diff --git a/Classes/Command/HealthCheckCommand.php b/Classes/Command/HealthCheckCommand.php index 90bdbb8..a1515ba 100644 --- a/Classes/Command/HealthCheckCommand.php +++ b/Classes/Command/HealthCheckCommand.php @@ -155,6 +155,8 @@ protected function removeDoubleWorks(): void $this->io->section('Removing double works'); $publishedItems = $this->publishedItemRepository->findAll(); $this->io->progressStart(count($publishedItems)); + + $works = []; foreach ($publishedItems as $publishedItem) { $this->io->progressAdvance(); foreach ($publishedItem->getContainedWorks() as $work) { @@ -172,7 +174,11 @@ protected function removeDoubleWorks(): void } foreach ($publishedItem->getPublishedSubitems() as $publishedSubitem) { foreach ($publishedSubitem->getContainedWorks() as $work) { - if (isset($works[$work->getGndId()]) && $works[$work->getGndId()]->getUid() != $work->getUid()) { + if ( + isset($works[$work->getGndId()]) && + $works[$work->getGndId()]->getUid() != $work->getUid() && + $work->getGndId() != 'lokal' + ) { $publishedSubitem->removeContainedWork($work); $publishedSubitem->addContainedWork($works[$work->getGndId()]); $this->io->text('detected double ' . $work->getGndId() . ', ' . $work->getFullTitle() . '.'); @@ -258,6 +264,8 @@ protected function removeUnusedWorks(): void { $this->io->section('Removing unused works'); $publishedItems = $this->publishedItemRepository->findAll(); + + // check works linked in published items and subitems foreach ($publishedItems as $publishedItem) { foreach ($publishedItem->getContainedWorks() as $work) { $works[$work->getUid()] = $work; @@ -268,6 +276,21 @@ protected function removeUnusedWorks(): void } } } + + // check works linked as super works + while (true) { + $initialWorkCount = count($works); + foreach ($works as $work) { + if($work->getSuperWork() != null) { + $works[$work->getSuperWork()->getUid()] = $work->getSuperWork(); + } + } + $newWorkCount = count($works); + if ($initialWorkCount == $newWorkCount) { + break; + } + } + $worksFromDb = $this->workRepository->findAll(); $this->io->progressStart(count($works)); foreach ($worksFromDb as $work) {