UpdateCommand.php 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <?php
  2. /**
  3. * Copyright © Magento, Inc. All rights reserved.
  4. * See COPYING.txt for license details.
  5. */
  6. namespace Magento\Analytics\Model\Connector;
  7. use Magento\Analytics\Model\AnalyticsToken;
  8. use Magento\Analytics\Model\Config\Backend\Baseurl\SubscriptionUpdateHandler;
  9. use Magento\Analytics\Model\Connector\Http\ResponseResolver;
  10. use Magento\Framework\App\Config\ScopeConfigInterface;
  11. use Magento\Framework\FlagManager;
  12. use Magento\Framework\HTTP\ZendClient;
  13. use Magento\Store\Model\Store;
  14. use Psr\Log\LoggerInterface;
  15. /**
  16. * Command executes in case change store url
  17. */
  18. class UpdateCommand implements CommandInterface
  19. {
  20. /**
  21. * @var string
  22. */
  23. private $updateUrlPath = 'analytics/url/update';
  24. /**
  25. * @var AnalyticsToken
  26. */
  27. private $analyticsToken;
  28. /**
  29. * @var Http\ClientInterface
  30. */
  31. private $httpClient;
  32. /**
  33. * @var ScopeConfigInterface
  34. */
  35. private $config;
  36. /**
  37. * @var LoggerInterface
  38. */
  39. private $logger;
  40. /**
  41. * @var FlagManager
  42. */
  43. private $flagManager;
  44. /**
  45. * @var ResponseResolver
  46. */
  47. private $responseResolver;
  48. /**
  49. * @param AnalyticsToken $analyticsToken
  50. * @param Http\ClientInterface $httpClient
  51. * @param ScopeConfigInterface $config
  52. * @param LoggerInterface $logger
  53. * @param FlagManager $flagManager
  54. * @param ResponseResolver $responseResolver
  55. */
  56. public function __construct(
  57. AnalyticsToken $analyticsToken,
  58. Http\ClientInterface $httpClient,
  59. ScopeConfigInterface $config,
  60. LoggerInterface $logger,
  61. FlagManager $flagManager,
  62. ResponseResolver $responseResolver
  63. ) {
  64. $this->analyticsToken = $analyticsToken;
  65. $this->httpClient = $httpClient;
  66. $this->config = $config;
  67. $this->logger = $logger;
  68. $this->flagManager = $flagManager;
  69. $this->responseResolver = $responseResolver;
  70. }
  71. /**
  72. * Executes update request to MBI api in case store url was changed
  73. *
  74. * @return bool
  75. */
  76. public function execute()
  77. {
  78. $result = false;
  79. if ($this->analyticsToken->isTokenExist()) {
  80. $response = $this->httpClient->request(
  81. ZendClient::PUT,
  82. $this->config->getValue($this->updateUrlPath),
  83. [
  84. "url" => $this->flagManager
  85. ->getFlagData(SubscriptionUpdateHandler::PREVIOUS_BASE_URL_FLAG_CODE),
  86. "new-url" => $this->config->getValue(Store::XML_PATH_SECURE_BASE_URL),
  87. "access-token" => $this->analyticsToken->getToken(),
  88. ]
  89. );
  90. $result = $this->responseResolver->getResult($response);
  91. if (!$result) {
  92. $this->logger->warning(
  93. sprintf(
  94. 'Update of the subscription for MBI service has been failed: %s. Content-Type: %s',
  95. !empty($response->getBody()) ? $response->getBody() : 'Response body is empty',
  96. $response->getHeader('Content-Type')
  97. )
  98. );
  99. }
  100. }
  101. return (bool)$result;
  102. }
  103. }