GitHub Access Token became invalid

It seems like the GitHub access token used for retrieving details about this repository from GitHub became invalid. This might prevent certain types of inspections from being run (in particular, everything related to pull requests).
Please ask an admin of your repository to re-new the access token on this website.
Completed
Push — master ( ce7c33...c8c4e6 )
by Andreas
03:55
created

ExportOrderConsumer::consume()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 15
Code Lines 9

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 2
eloc 9
c 1
b 0
f 1
nc 2
nop 1
dl 0
loc 15
rs 9.9666
1
<?php
2
declare(strict_types=1);
3
/**
4
 */
5
6
namespace CommerceLeague\ActiveCampaign\MessageQueue;
7
8
use CommerceLeague\ActiveCampaign\Api\Data\OrderInterface;
9
use CommerceLeague\ActiveCampaign\Api\OrderRepositoryInterface;
10
use CommerceLeague\ActiveCampaign\Gateway\Client;
11
use CommerceLeague\ActiveCampaign\Logger\Logger;
12
use CommerceLeague\ActiveCampaignApi\Exception\HttpException;
13
use Magento\Framework\Exception\CouldNotSaveException;
14
15
/**
16
 * Class ExportOrderConsumer
17
 */
18
class ExportOrderConsumer
19
{
20
    /**
21
     * @var OrderRepositoryInterface
22
     */
23
    private $orderRepository;
24
25
    /**
26
     * @var Logger
27
     */
28
    private $logger;
29
30
    /**
31
     * @var Client
32
     */
33
    private $client;
34
35
    /**
36
     * @param OrderRepositoryInterface $orderRepository
37
     * @param Logger $logger
38
     * @param Client $client
39
     */
40
    public function __construct(
41
        OrderRepositoryInterface $orderRepository,
42
        Logger $logger,
43
        Client $client
44
    ) {
45
        $this->orderRepository = $orderRepository;
46
        $this->logger = $logger;
47
        $this->client = $client;
48
    }
49
50
    /**
51
     * @param string $message
52
     * @throws CouldNotSaveException
53
     */
54
    public function consume(string $message): void
55
    {
56
        $message = json_decode($message, true);
57
        $order = $this->orderRepository->getOrCreateByMagentoOrderId($message['magento_order_id']);
58
59
        try {
60
            $apiResponse = $this->performApiRequest($order, $message['request']);
61
        } catch (HttpException $e) {
62
            $this->logger->err($e->getMessage());
63
            return;
64
        }
65
66
        $order->setActiveCampaignId($apiResponse['ecomOrder']['id']);
67
68
        $this->orderRepository->save($order);
69
    }
70
71
    /**
72
     * @param OrderInterface $order
73
     * @param array $request
74
     * @return array
75
     */
76
    private function performApiRequest(OrderInterface $order, array $request): array
77
    {
78
        if ($activeCampaignId = $order->getActiveCampaignId()) {
79
            return $this->client->getOrderApi()->update((int)$activeCampaignId, ['ecomOrder' => $request]);
80
        } else {
81
            return $this->client->getOrderApi()->create(['ecomOrder' => $request]);
82
        }
83
    }
84
}
85