Skip to content

Commit

Permalink
Merge pull request #4452 from neos/feature/4200-replay-progress-bar
Browse files Browse the repository at this point in the history
FEATURE: Progress bar for projection replay
  • Loading branch information
skurfuerst authored Sep 1, 2023
2 parents 11cbcc1 + 9bc2085 commit 6088b17
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 2 deletions.
5 changes: 4 additions & 1 deletion Classes/ContentRepository.php
Original file line number Diff line number Diff line change
Expand Up @@ -170,8 +170,11 @@ public function catchUpProjection(string $projectionClassName, CatchUpOptions $o
$eventStream = $eventStream->withMaximumSequenceNumber($options->maximumSequenceNumber);
}

$eventApplier = function (EventEnvelope $eventEnvelope) use ($projection, $catchUpHook) {
$eventApplier = function (EventEnvelope $eventEnvelope) use ($projection, $catchUpHook, $options) {
$event = $this->eventNormalizer->denormalize($eventEnvelope->event);
if ($options->progressCallback !== null) {
($options->progressCallback)($event, $eventEnvelope);
}
if (!$projection->canHandle($event)) {
return;
}
Expand Down
10 changes: 9 additions & 1 deletion Classes/Projection/CatchUpOptions.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,11 @@

namespace Neos\ContentRepository\Core\Projection;

use Closure;
use Neos\ContentRepository\Core\ContentRepository;
use Neos\ContentRepository\Core\EventStore\EventInterface;
use Neos\EventStore\Model\Event\SequenceNumber;
use Neos\EventStore\Model\EventEnvelope;

/**
* Options for {@see ContentRepository::catchUpProjection()}
Expand All @@ -16,9 +19,11 @@ final class CatchUpOptions
{
/**
* @param SequenceNumber|null $maximumSequenceNumber If specified the catch-up will stop at the specified {@see SequenceNumber}
* @param Closure(EventInterface $event, EventEnvelope $eventEnvelope): void|null $progressCallback If specified the given closure will be invoked for every event with the current {@see EventInterface} and {@see EventEnvelope} passed as arguments
*/
private function __construct(
public readonly ?SequenceNumber $maximumSequenceNumber,
public readonly ?Closure $progressCallback,
) {
}

Expand All @@ -30,11 +35,12 @@ private function __construct(
*/
public static function create(
SequenceNumber|int|null $maximumSequenceNumber = null,
Closure|null $progressCallback = null,
): self {
if (is_int($maximumSequenceNumber)) {
$maximumSequenceNumber = SequenceNumber::fromInteger($maximumSequenceNumber);
}
return new self($maximumSequenceNumber);
return new self($maximumSequenceNumber, $progressCallback);
}


Expand All @@ -46,9 +52,11 @@ public static function create(
*/
public function with(
SequenceNumber|int|null $maximumSequenceNumber = null,
Closure|null $progressCallback = null,
): self {
return self::create(
$maximumSequenceNumber ?? $this->maximumSequenceNumber,
$progressCallback ?? $this->progressCallback,
);
}
}

0 comments on commit 6088b17

Please sign in to comment.