From eb3bf156b1eca6987e3c94a5ac427d9a0f6bbca6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jan=20Bar=C3=A1=C5=A1ek?= Date: Thu, 10 Feb 2022 10:07:31 +0100 Subject: [PATCH] CheckOrderCommand: Fix internal logic. --- src/Command/CheckOrderCommand.php | 47 +++++++++++++++---------------- 1 file changed, 22 insertions(+), 25 deletions(-) diff --git a/src/Command/CheckOrderCommand.php b/src/Command/CheckOrderCommand.php index c964851..f155adc 100644 --- a/src/Command/CheckOrderCommand.php +++ b/src/Command/CheckOrderCommand.php @@ -19,8 +19,6 @@ use Symfony\Component\Console\Command\Command; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Output\OutputInterface; -use Tracy\Debugger; -use Tracy\ILogger; final class CheckOrderCommand extends Command { @@ -51,7 +49,8 @@ protected function execute(InputInterface $input, OutputInterface $output): int $orders = $this->entityManager->getRepository(Order::class) ->createQueryBuilder('orderEntity') ->leftJoin('orderEntity.status', 'status') - ->where('status.code = :code') + ->where('orderEntity.paid = FALSE') + ->andWhere('status.code = :code') ->setParameter('code', OrderStatus::STATUS_NEW) ->getQuery() ->getResult(); @@ -126,27 +125,26 @@ private function updateStatusByWorkflow(Order $order): void */ private function checkUnmatchedTransactions(array $unauthorizedVariables, Authorizator $authorizator): void { - try { - $processed = []; - $unmatchedTransactionsList = $authorizator->getUnmatchedTransactions($unauthorizedVariables); - foreach ($unmatchedTransactionsList as $transaction) { - assert($transaction instanceof \Baraja\FioPaymentAuthorizator\Transaction); - if ( - isset($processed[$transaction->getIdTransaction()]) === false - && $this->tm->transactionExist((int) $transaction->getIdTransaction()) === false - && $this->tm->orderHasPaidByVariableSymbol($transaction->getVariableSymbol()) === false - ) { - if ($transaction->getPrice() > 0) { - $this->tm->storeUnmatchedTransaction($transaction); - } - echo $transaction->getIdTransaction() . "\n"; - $this->tm->storeTransaction($transaction, true); - $processed[$transaction->getIdTransaction()] = true; + $processed = []; + $unmatchedTransactionsList = $authorizator->getUnmatchedTransactions($unauthorizedVariables); + foreach ($unmatchedTransactionsList as $transaction) { + assert($transaction instanceof \Baraja\FioPaymentAuthorizator\Transaction); + $idTransaction = $transaction->getIdTransaction(); + if ($idTransaction === null) { + continue; + } + if ( + isset($processed[$idTransaction]) === false + && $this->tm->transactionExist($idTransaction) === false + && $this->tm->orderHasPaidByVariableSymbol($transaction->getVariableSymbol()) === false + ) { + if ($transaction->getPrice() > 0) { + $this->tm->storeUnmatchedTransaction($transaction); } + echo $idTransaction . "\n"; + $this->tm->storeTransaction($transaction, true); + $processed[$idTransaction] = true; } - } catch (\Throwable $e) { - Debugger::log($e, ILogger::CRITICAL); - die; } } @@ -179,11 +177,10 @@ private function authOrders(array $unauthorizedVariables, array $orderByVariable $unauthorizedVariables, $callback, 'CZK', - 0.25 + 0.25, ); } catch (\Throwable $e) { - Debugger::log($e, ILogger::CRITICAL); - die; + throw new \RuntimeException(sprintf('Can not authorize orders: %s', $e->getMessage()), 500, $e); } }