123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- <?php
- /**
- * Refer to LICENSE.txt distributed with the Temando Shipping module for notice of license
- */
- namespace Temando\Shipping\Sync;
- use Magento\Framework\Exception\CouldNotDeleteException;
- use Magento\Framework\Exception\LocalizedException;
- use Psr\Log\LoggerInterface;
- use Temando\Shipping\Model\Config\ModuleConfigInterface;
- use Temando\Shipping\Model\ResourceModel\EventStream\EventRepositoryInterface;
- use Temando\Shipping\Model\StreamEventInterface;
- /**
- * Temando Event Stream Processor
- *
- * @package Temando\Shipping\Sync
- * @author Benjamin Heuer <benjamin.heuer@netresearch.de>
- * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
- * @link http://www.temando.com/
- */
- class EventStreamProcessor
- {
- /**
- * @var ModuleConfigInterface
- */
- private $config;
- /**
- * @var EventListProcessor
- */
- private $eventListProcessor;
- /**
- * @var EventRepositoryInterface
- */
- private $streamEventRepository;
- /**
- * @var EventFilter
- */
- private $streamEventFilter;
- /**
- * @var LoggerInterface
- */
- private $logger;
- /**
- * @param ModuleConfigInterface $config
- * @param EventListProcessor $eventListProcessor
- * @param EventRepositoryInterface $streamEventRepository
- * @param EventFilter $streamEventFilter
- * @param LoggerInterface $logger
- */
- public function __construct(
- ModuleConfigInterface $config,
- EventListProcessor $eventListProcessor,
- EventRepositoryInterface $streamEventRepository,
- EventFilter $streamEventFilter,
- LoggerInterface $logger
- ) {
- $this->config = $config;
- $this->eventListProcessor = $eventListProcessor;
- $this->streamEventRepository = $streamEventRepository;
- $this->streamEventFilter = $streamEventFilter;
- $this->logger = $logger;
- }
- /**
- * @param int $iterations
- * @return void
- */
- public function processEvents($iterations = 10)
- {
- $streamId = $this->config->getStreamId();
- $eventList = EventList::fromArray([]);
- do {
- $iterations--;
- try {
- // obtain next events, pass on to list processor
- $streamEvents = $this->streamEventRepository->getEventList($streamId);
- $processableEvents = $this->streamEventFilter->filter($streamEvents);
- $this->eventListProcessor->processEventList($processableEvents, $eventList);
- } catch (LocalizedException $e) {
- $this->logger->error($e->getMessage(), ['exception' => $e]);
- continue;
- }
- $deleteStreamEvent = function (StreamEventInterface $streamEvent) use ($streamId, $eventList) {
- if (!$eventList->hasEvent($streamEvent->getEventId())) {
- $this->streamEventRepository->delete($streamId, $streamEvent->getEventId());
- }
- };
- try {
- // delete events that were processed successfully (removed from event list)
- array_walk($streamEvents, $deleteStreamEvent);
- } catch (CouldNotDeleteException $e) {
- $this->logger->error($e->getMessage(), ['exception' => $e]);
- }
- } while ($iterations > 0 && !empty($streamEvents));
- }
- }
|