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 ( a2b3b2...f1cd39 )
by Andreas
03:20
created

SyncCustomerConsumer::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 8
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 3
nc 1
nop 3
dl 0
loc 8
rs 10
c 0
b 0
f 0
1
<?php
2
declare(strict_types=1);
3
/**
4
 */
5
6
namespace CommerceLeague\ActiveCampaign\MessageQueue\Customer;
7
8
use CommerceLeague\ActiveCampaign\Api\CustomerRepositoryInterface;
9
use CommerceLeague\ActiveCampaign\Api\Data\CustomerInterface;
10
use CommerceLeague\ActiveCampaign\Helper\Client as ClientHelper;
11
use CommerceLeague\ActiveCampaign\Logger\Logger;
12
use CommerceLeague\ActiveCampaignApi\Exception\HttpException;
13
use Magento\Framework\Exception\CouldNotSaveException;
14
use Magento\Framework\Model\AbstractModel;
15
16
/**
17
 * Class SyncCustomerConsumer
18
 */
19
class SyncCustomerConsumer
20
{
21
    /**
22
     * @var CustomerRepositoryInterface
23
     */
24
    private $customerRepository;
25
26
    /**
27
     * @var Logger
28
     */
29
    private $logger;
30
31
    /**
32
     * @var ClientHelper
33
     */
34
    private $clientHelper;
35
36
    /**
37
     * @param CustomerRepositoryInterface $customerRepository
38
     * @param Logger $logger
39
     * @param ClientHelper $clientHelper
40
     */
41
    public function __construct(
42
        CustomerRepositoryInterface $customerRepository,
43
        Logger $logger,
44
        ClientHelper $clientHelper
45
    ) {
46
        $this->customerRepository = $customerRepository;
47
        $this->logger = $logger;
48
        $this->clientHelper = $clientHelper;
49
    }
50
51
    /**
52
     * @param string $message
53
     */
54
    public function consume(string $message): void
55
    {
56
        $message = json_decode($message, true);
57
58
        try {
59
            /** @var AbstractModel|CustomerInterface $customer */
60
            $customer = $this->customerRepository->getOrCreateByMagentoCustomerId($message['magento_customer_id']);
61
        } catch (CouldNotSaveException $e) {
62
            $this->logger->error(__('Unable to find customer with id "%1".', $message->getEntityId()));
63
            return;
64
        }
65
66
        try {
67
            $apiResponse = $this->performApiRequest($customer, $message['request']);
68
        } catch (HttpException $e) {
69
            $this->logger->error($e->getMessage());
70
            return;
71
        }
72
73
        $customer->setActiveCampaignId($apiResponse['ecomCustomer']['id']);
74
75
        try {
76
            $this->customerRepository->save($customer);
77
        } catch (CouldNotSaveException $e) {
78
            $this->logger->error($e->getMessage());
79
        }
80
    }
81
82
    /**
83
     * @param CustomerInterface $customer
84
     * @param array $request
85
     * @return array
86
     * @throws HttpException
87
     */
88
    private function performApiRequest(CustomerInterface $customer, array $request): array
89
    {
90
        if ($activeCampaignId = $customer->getActiveCampaignId()) {
91
            return $this->clientHelper->getCustomerApi()->update((int)$activeCampaignId, ['ecomCustomer' => $request]);
92
        } else {
93
            return $this->clientHelper->getCustomerApi()->create(['ecomCustomer' => $request]);
94
        }
95
    }
96
}
97