diff --git a/Block/Adminhtml/System/Config/Form/Field/HubIntegration.php b/Block/Adminhtml/System/Config/Form/Field/HubIntegration.php
index c7fa226a..e05ce128 100644
--- a/Block/Adminhtml/System/Config/Form/Field/HubIntegration.php
+++ b/Block/Adminhtml/System/Config/Form/Field/HubIntegration.php
@@ -5,8 +5,8 @@
use Exception;
use Magento\Backend\Block\Template\Context;
use Magento\Config\Block\System\Config\Form\Field;
+use Magento\Framework\App\Config\ScopeConfigInterface;
use Magento\Framework\Data\Form\Element\AbstractElement;
-use Magento\Framework\Phrase;
use Pagarme\Core\Hub\Services\HubIntegrationService;
use Pagarme\Pagarme\Concrete\Magento2CoreSetup;
use Pagarme\Pagarme\Model\Account;
@@ -18,12 +18,16 @@ class HubIntegration extends Field
*/
private $account;
+ protected $scopeConfig;
+
public function __construct(
Account $account,
+ ScopeConfigInterface $scopeConfig,
Context $context,
array $data = []
) {
$this->account = $account;
+ $this->scopeConfig = $scopeConfig;
parent::__construct($context, $data);
}
@@ -32,31 +36,46 @@ public function __construct(
* @return string
* @throws Exception
*/
- protected function _renderValue(AbstractElement $element)
+ protected function _renderValue(AbstractElement $element): string
{
Magento2CoreSetup::bootstrap();
- $installId = Magento2CoreSetup::getModuleConfiguration()
- ->getHubInstallId();
-
- $hubUrl = $this->getHubUrl($installId);
- $buttonText = $this->getButtonText($installId);
+ $installId = Magento2CoreSetup::getModuleConfiguration()->getHubInstallId();
+ $installIdValue = !empty($installId) ? $installId->getValue() : '';
+ $defaultInstallId = $this->scopeConfig->getValue(
+ 'pagarme_pagarme/hub/install_id',
+ ScopeConfigInterface::SCOPE_TYPE_DEFAULT,
+ 0
+ );
+ $defaultInstallId = $defaultInstallId ?? '';
- $html = '
';
+ $html = sprintf(
+ ' | ',
+ $installIdValue === $defaultInstallId ? 'default' : 'scope'
+ );
$html .= $this->_getElementHtml($element);
+ $hidden = ' hidden';
$html .= sprintf(
- '%s',
- $hubUrl,
- $buttonText
+ '%s',
+ $this->getBaseIntegrateUrl(),
+ $installId ? $hidden : '',
+ __("Integrate With Pagar.me")
+ );
+
+ $html .= sprintf(
+ '%s',
+ $this->getHubUrl($installId),
+ $installId ? '' : $hidden,
+ __("View Integration")
);
if ($this->account->hasMerchantAndAccountIds()) {
- $dashUrl = $this->account->getDashUrl();
$html .= sprintf(
- '%s',
- $dashUrl,
+ '%s',
+ $this->account->getDashUrl(),
+ $installId ? '' : $hidden,
__('Access Pagar.me Dash')
);
}
@@ -66,16 +85,6 @@ protected function _renderValue(AbstractElement $element)
return $html;
}
- /**
- * @param $installId
- * @return Phrase
- */
- private function getButtonText($installId): Phrase
- {
- return $installId
- ? __("View Integration") : __("Integrate With Pagar.me");
- }
-
/**
* @param $installId
* @return string
@@ -97,12 +106,20 @@ private function getBaseIntegrateUrl(): string
$this->getPublicAppKey()
);
- $params = sprintf(
- '?redirect=%swebsite/%s/&install_token/%s',
- $this->getRedirectUrl(),
- Magento2CoreSetup::getCurrentStoreId(),
- $this->getInstallToken()
- );
+ if($this->getRequest()->getParam('website') !== null) {
+ $params = sprintf(
+ '?redirect=%swebsite/%s/&install_token/%s',
+ $this->getRedirectUrl(),
+ Magento2CoreSetup::getCurrentStoreId(),
+ $this->getInstallToken()
+ );
+ } else {
+ $params = sprintf(
+ '?redirect=%s&install_token/%s',
+ $this->getRedirectUrl(),
+ $this->getInstallToken()
+ );
+ }
return $baseUrl . $params;
}
diff --git a/Concrete/Magento2CoreSetup.php b/Concrete/Magento2CoreSetup.php
index a61ec500..8874c0b6 100644
--- a/Concrete/Magento2CoreSetup.php
+++ b/Concrete/Magento2CoreSetup.php
@@ -2,37 +2,29 @@
namespace Pagarme\Pagarme\Concrete;
-use Magento\Framework\App\Config as Magento2StoreConfig;
+use DateTimeZone;
+use Exception;
use Magento\Config\Model\Config as Magento2ModelConfig;
+use Magento\Framework\App\Config as Magento2StoreConfig;
use Magento\Framework\App\Config\ScopeConfigInterface;
-use Magento\Framework\Stdlib\DateTime\TimezoneInterface;
-use Magento\Store\Model\ScopeInterface as ScopeInterface;
use Magento\Framework\App\ObjectManager;
use Magento\Framework\App\ProductMetadataInterface;
use Magento\Framework\Filesystem\DirectoryList;
-use Magento\Store\Model\StoreManager as MagentoStoreManager;
+use Magento\Framework\Stdlib\DateTime\TimezoneInterface;
+use Magento\Store\Model\ScopeInterface;
+use Magento\Store\Model\StoreManagerInterface;
+use Magento\Store\Model\Website\Interceptor;
use Pagarme\Core\Kernel\Abstractions\AbstractModuleCoreSetup;
use Pagarme\Core\Kernel\Aggregates\Configuration;
use Pagarme\Core\Kernel\Factories\ConfigurationFactory;
use Pagarme\Core\Kernel\Services\MoneyService;
use Pagarme\Core\Kernel\ValueObjects\CardBrand;
use Pagarme\Core\Kernel\ValueObjects\Configuration\CardConfig;
-use Pagarme\Pagarme\Gateway\Transaction\Base\Config\Config;
-use Pagarme\Pagarme\Gateway\Transaction\CreditCard\Config\ConfigInterface;
-use Pagarme\Pagarme\Model\Installments\Config\ConfigInterface as InstallmentConfigInterface;
use Pagarme\Pagarme\Helper\ModuleHelper;
-use Pagarme\Pagarme\Model\Enum\CreditCardBrandEnum;
-use Pagarme\Pagarme\Concrete\Magento2DatabaseDecorator;
-use Pagarme\Pagarme\Concrete\Magento2PlatformOrderDecorator;
-use Pagarme\Pagarme\Concrete\Magento2PlatformInvoiceDecorator;
-use Pagarme\Pagarme\Concrete\Magento2PlatformCreditmemoDecorator;
-use Pagarme\Pagarme\Concrete\Magento2DataService;
-use Pagarme\Pagarme\Concrete\Magento2PlatformPaymentMethodDecorator;
-use Pagarme\Pagarme\Concrete\Magento2PlatformProductDecorator;
use Pagarme\Pagarme\Model\ConfigNotification;
-use Magento\Store\Model\StoreManagerInterface;
-use Magento\Store\Model\Website\Interceptor;
+use Pagarme\Pagarme\Model\Enum\CreditCardBrandEnum;
use stdClass;
+use Throwable;
final class Magento2CoreSetup extends AbstractModuleCoreSetup
{
@@ -74,19 +66,19 @@ protected function setConfig()
{
self::$config = [
AbstractModuleCoreSetup::CONCRETE_DATABASE_DECORATOR_CLASS =>
- Magento2DatabaseDecorator::class,
+ Magento2DatabaseDecorator::class,
AbstractModuleCoreSetup::CONCRETE_PLATFORM_ORDER_DECORATOR_CLASS =>
- Magento2PlatformOrderDecorator::class,
+ Magento2PlatformOrderDecorator::class,
AbstractModuleCoreSetup::CONCRETE_PLATFORM_INVOICE_DECORATOR_CLASS =>
- Magento2PlatformInvoiceDecorator::class,
+ Magento2PlatformInvoiceDecorator::class,
AbstractModuleCoreSetup::CONCRETE_PLATFORM_CREDITMEMO_DECORATOR_CLASS =>
- Magento2PlatformCreditmemoDecorator::class,
+ Magento2PlatformCreditmemoDecorator::class,
AbstractModuleCoreSetup::CONCRETE_DATA_SERVICE =>
- Magento2DataService::class,
+ Magento2DataService::class,
AbstractModuleCoreSetup::CONCRETE_PLATFORM_PAYMENT_METHOD_DECORATOR_CLASS =>
- Magento2PlatformPaymentMethodDecorator::class,
+ Magento2PlatformPaymentMethodDecorator::class,
AbstractModuleCoreSetup::CONCRETE_PRODUCT_DECORATOR_CLASS =>
- Magento2PlatformProductDecorator::class
+ Magento2PlatformProductDecorator::class
];
}
@@ -134,7 +126,7 @@ public function loadModuleConfigurationFromPlatform($storeConfig = null)
$storeConfig = $objectManager->get(Magento2StoreConfig::class);
}
- $configData = new \stdClass();
+ $configData = new stdClass();
$storeId = self::getCurrentStoreId();
@@ -167,7 +159,7 @@ public function loadModuleConfigurationFromPlatform($storeConfig = null)
self::$moduleConfig = $config;
self::$instance->setApiBaseUrl();
- } catch (\Throwable $error) {
+ } catch (Throwable $error) {
$configErrorNotify = new ConfigNotification();
$configErrorNotify->addNotify($error);
}
@@ -212,13 +204,13 @@ static private function fillWithVoucherConfig(&$dataObj, $storeConfig)
$section = 'payment/pagarme_voucher/';
- $voucherObject = new \stdClass();
+ $voucherObject = new stdClass();
$dataObj->voucherConfig = self::fillDataObj($storeConfig, $options, $voucherObject, $section);
$operation = Configuration::CARD_OPERATION_AUTH_ONLY;
if ($dataObj->voucherConfig->cardOperation === 'authorize_capture') {
- $operation = Configuration::CARD_OPERATION_AUTH_AND_CAPTURE;
+ $operation = Configuration::CARD_OPERATION_AUTH_AND_CAPTURE;
}
$dataObj->voucherConfig->cardOperation = $operation;
@@ -237,7 +229,7 @@ static private function fillWithDebitConfig(&$dataObj, $storeConfig)
$section = 'payment/pagarme_debit/';
- $debitObject = new \stdClass();
+ $debitObject = new stdClass();
$dataObj->debitConfig = self::fillDataObj($storeConfig, $options, $debitObject, $section);
$dataObj->debitConfig->cardOperation = Configuration::CARD_OPERATION_AUTH_AND_CAPTURE;
@@ -279,9 +271,10 @@ static private function fillWithCardConfig(&$dataObj, $storeConfig)
}
private static function fillWithPixConfig(
- stdClass $configData,
+ stdClass $configData,
ScopeConfigInterface $storeConfig
- ) {
+ )
+ {
$options = [
'enabled' => 'active',
'expirationQrCode' => 'expiration_qrcode',
@@ -291,15 +284,16 @@ private static function fillWithPixConfig(
$section = 'payment/pagarme_pix/';
- $pixObject = new \stdClass();
+ $pixObject = new stdClass();
$configData->pixConfig = self::fillDataObj($storeConfig, $options, $pixObject, $section);
}
-
+
private static function fillWithGooglePayConfig(
- stdClass $configData,
+ stdClass $configData,
ScopeConfigInterface $storeConfig
- ) {
+ )
+ {
$options = [
'enabled' => 'active',
'title' => 'title',
@@ -309,7 +303,7 @@ private static function fillWithGooglePayConfig(
$section = 'payment/pagarme_googlepay/';
- $googlePayObject = new \stdClass();
+ $googlePayObject = new stdClass();
$configData->googlePayConfig = self::fillDataObj($storeConfig, $options, $googlePayObject, $section);
}
@@ -380,7 +374,7 @@ static private function fillWithPagarmeKeys(&$dataObj, $storeConfig)
$section = 'pagarme_pagarme/global/';
- $keys = new \stdClass;
+ $keys = new stdClass;
$dataObj->keys =
self::fillDataObj(
@@ -415,7 +409,7 @@ static private function fillWithAddressConfig(&$dataObj, $storeConfig)
];
$section = 'payment/pagarme_customer_address/';
- $addressAttributes = new \stdClass();
+ $addressAttributes = new stdClass();
$dataObj->addressAttributes =
self::fillDataObj(
$storeConfig,
@@ -455,7 +449,7 @@ static private function getBrandConfig($storeConfig, $section)
$scope = ScopeInterface::SCOPE_WEBSITES;
$storeId = self::getCurrentStoreId();
- $selectedBrands = $storeConfig->getValue($section . 'cctypes', $scope, $storeId) ?? '';
+ $selectedBrands = $storeConfig->getValue($section . 'cctypes', $scope, $storeId) ?? '';
$brands = array_merge([''], explode(
',',
$selectedBrands
@@ -482,12 +476,12 @@ static private function getBrandConfig($storeConfig, $section)
$max = $storeConfig->getValue($section . 'installments_number' . $brand, $scope, $storeId);
}
- $minValue = $storeConfig->getValue($section . 'installment_min_amount' . $brand, $scope, $storeId);
- $initial = $storeConfig->getValue($section . 'installments_interest_rate_initial' . $brand, $scope, $storeId);
- $incremental = $storeConfig->getValue($section . 'installments_interest_rate_incremental' . $brand, $scope, $storeId);
- $maxWithout = $storeConfig->getValue($section . 'installments_max_without_interest' . $brand, $scope, $storeId);
+ $minValue = $storeConfig->getValue($section . 'installment_min_amount' . $brand, $scope, $storeId);
+ $initial = $storeConfig->getValue($section . 'installments_interest_rate_initial' . $brand, $scope, $storeId);
+ $incremental = $storeConfig->getValue($section . 'installments_interest_rate_incremental' . $brand, $scope, $storeId);
+ $maxWithout = $storeConfig->getValue($section . 'installments_max_without_interest' . $brand, $scope, $storeId);
- $interestByBrand = $storeConfig->getValue($section . 'installments_interest_by_issuer' . $brand, $scope, $storeId);
+ $interestByBrand = $storeConfig->getValue($section . 'installments_interest_by_issuer' . $brand, $scope, $storeId);
if (empty($interestByBrand)) {
$initial = 0;
$incremental = 0;
@@ -541,46 +535,41 @@ public static function getDefaultStoreViewCode()
public static function getCurrentStoreId()
{
$objectManager = ObjectManager::getInstance();
- $config = $objectManager->get(Magento2ModelConfig::class);
- $storeInterfaceName = '\Magento\Store\Model\StoreManagerInterface';
- $storeManager = $objectManager->get($storeInterfaceName);
+ $requestClass = '\Magento\Framework\App\RequestInterface';
+ $request = $objectManager->get($requestClass);
- $store = $storeManager->getWebsite()->getId();
+ if ($request->getControllerName() !== 'system_config') {
+ $storeInterfaceName = '\Magento\Store\Model\StoreManagerInterface';
+ $storeManager = $objectManager->get($storeInterfaceName);
- if ($config->getScope() == 'websites') {
- $store = $config->getScopeId();
+ return $storeManager->getStore()->getWebsite()->getId();
}
- if ($config->getScope() == 'stores') {
- $store = $storeManager
- ->getStore($config->getScopeId())
- ->getWebsite()
- ->getId();
+ if ($request->getParam(ScopeInterface::SCOPE_WEBSITE)) {
+ return $request->getParam(ScopeInterface::SCOPE_WEBSITE);
}
- if ($config->getScope() == 'default') {
- $store = $storeManager->getDefaultStoreView()->getStoreId();
+ if ($request->getParam(ScopeInterface::SCOPE_STORE)) {
+ return $request->getParam(ScopeInterface::SCOPE_STORE);
}
- return $store;
+ return 0;
}
+ /**
+ * @return int
+ */
public static function getDefaultStoreId()
{
- $objectManager = ObjectManager::getInstance();
- $storeInterfaceName = '\Magento\Store\Model\StoreManagerInterface';
- $storeManager = $objectManager->get($storeInterfaceName);
-
- $defaultStoreView = $storeManager->getDefaultStoreView();
-
- return $defaultStoreView->getStoreId();
+ return 0;
}
/**
+ * @return DateTimeZone
+ * @throws Exception
* @since 1.7.1
*
- * @return \DateTimeZone
*/
protected function getPlatformStoreTimezone()
{
@@ -592,9 +581,8 @@ protected function getPlatformStoreTimezone()
$timezoneString = $timezone->getConfigTimezone(
ScopeInterface::SCOPE_STORE
);
- $dateTimeZone = new \DateTimeZone($timezoneString);
- return $dateTimeZone;
+ return new DateTimeZone($timezoneString);
}
static private function fillWithRecurrenceConfig(&$dataObj, $storeConfig)
@@ -622,7 +610,7 @@ static private function fillWithRecurrenceConfig(&$dataObj, $storeConfig)
$section = 'pagarme_pagarme/recurrence/';
- $recurrenceConfig = new \stdClass();
+ $recurrenceConfig = new stdClass();
$dataObj->recurrenceConfig = self::fillDataObj(
$storeConfig,
$options,
@@ -632,9 +620,10 @@ static private function fillWithRecurrenceConfig(&$dataObj, $storeConfig)
}
static private function fillWithMarketplaceConfig(
- stdClass $configData,
+ stdClass $configData,
ScopeConfigInterface $storeConfig
- ) {
+ )
+ {
$options = [
'enabled' => 'active',
'responsibilityForProcessingFees'
@@ -651,7 +640,7 @@ static private function fillWithMarketplaceConfig(
$section = 'pagarme_pagarme/marketplace/';
- $marketplaceObject = new \stdClass();
+ $marketplaceObject = new stdClass();
$configData->marketplaceConfig = self::fillDataObj($storeConfig, $options, $marketplaceObject, $section);
}
diff --git a/Controller/Adminhtml/Hub/Index.php b/Controller/Adminhtml/Hub/Index.php
index 4161cf3c..82c713c2 100644
--- a/Controller/Adminhtml/Hub/Index.php
+++ b/Controller/Adminhtml/Hub/Index.php
@@ -2,17 +2,23 @@
namespace Pagarme\Pagarme\Controller\Adminhtml\Hub;
+use Magento\Backend\App\Action;
use Magento\Backend\App\Action\Context;
use Magento\Framework\App\Cache\Manager;
+use Magento\Framework\App\Config\ScopeConfigInterface;
use Magento\Framework\App\Config\Storage\WriterInterface;
use Magento\Framework\App\RequestInterface;
+use Magento\Framework\Controller\ResultInterface;
+use Magento\Framework\Exception\LocalizedException;
+use Magento\Framework\Exception\NoSuchEntityException;
use Magento\Framework\View\Result\PageFactory;
use Magento\Framework\Webapi\Exception as MagentoException;
+use Magento\Store\Model\ScopeInterface;
use Magento\Store\Model\StoreManagerInterface;
use Pagarme\Core\Hub\Services\HubIntegrationService;
use Pagarme\Pagarme\Concrete\Magento2CoreSetup;
-class Index extends \Magento\Backend\App\Action
+class Index extends Action
{
protected $resultPageFactory;
protected $configWriter;
@@ -50,18 +56,16 @@ public function __construct(
/**
* Index action
*
- * @return \Magento\Framework\Controller\ResultInterface
+ * @return ResultInterface
+ * @throws MagentoException|LocalizedException
+ * @throws \Exception
*/
public function execute()
{
$params = $this->requestObject->getParams();
- $websiteId = isset($params['website'])
- ? $params['website']
- : $this->storeManager->getDefaultStoreView()->getWebsiteId();
-
- $storeId = $this->storeManager->getWebsite($websiteId)
- ->getDefaultStore()->getId();
- $this->storeManager->setCurrentStore($storeId);
+ $scopeUrl = $this->getScopeUrl();
+ $websiteId = $params['website'] ?? 0;
+ $this->storeManager->setCurrentStore($websiteId);
Magento2CoreSetup::bootstrap();
@@ -85,161 +89,145 @@ public function execute()
}
$url = $this->getUrl('adminhtml/system_config/edit/section/payment');
- header('Location: ' . explode('?', $url ?? '')[0] . 'website/' . $websiteId);
+ $header = 'Location: ' . explode('?', $url ?? '')[0];
+ if (!empty($websiteId) && !empty($scopeUrl)) {
+ $header .= $scopeUrl . '/' . $websiteId;
+ }
+ header($header);
exit;
}
- private function getCallbackUrl($websiteId)
- {
- $baseUrl = $this->storeManager->getStore()->getBaseUrl();
- return $baseUrl . "rest/V1/pagarme/hub/command?websiteId=" . $websiteId;
- }
-
- private function getWebHookkUrl()
+ /**
+ * @return string
+ */
+ public function getScopeName(): string
{
- $baseUrl = $this->storeManager->getStore()->getBaseUrl();
- return $baseUrl . "rest/V1/pagarme/webhook";
- }
+ $request = $this->requestObject;
- private function allWebsitesIntegrated($currentWebsiteId)
- {
- $websites = $this->storeManager->getWebsites();
- $magento2CoreSetup = new Magento2CoreSetup();
+ if ($request->getParam(ScopeInterface::SCOPE_WEBSITE)) {
+ return ScopeInterface::SCOPE_WEBSITES;
+ }
- foreach ($websites as $websiteId => $website) {
- $storeId = $this->storeManager->getWebsite($websiteId)
- ->getDefaultStore()->getId();
+ if ($request->getParam(ScopeInterface::SCOPE_STORE)) {
+ return ScopeInterface::SCOPE_STORES;
+ }
- $this->storeManager->setCurrentStore($storeId);
+ return ScopeConfigInterface::SCOPE_TYPE_DEFAULT;
+ }
- $magento2CoreSetup->loadModuleConfigurationFromPlatform();
- $currentConfiguration = Magento2CoreSetup::getModuleConfiguration();
+ /**
+ * @return string|null
+ */
+ public function getScopeUrl()
+ {
+ $request = $this->requestObject;
- $isSameWebsite = $websiteId === intval($currentWebsiteId);
+ if ($request->getParam(ScopeInterface::SCOPE_WEBSITE)) {
+ return ScopeInterface::SCOPE_WEBSITE;
+ }
- if (!$isSameWebsite && !$currentConfiguration->isHubEnabled()) {
- return false;
- }
+ if ($request->getParam(ScopeInterface::SCOPE_STORE)) {
+ return ScopeInterface::SCOPE_STORE;
}
- return true;
+ return null;
}
- private function removeDefaultConfigKeys()
+ /**
+ * @param $websiteId
+ * @return string
+ * @throws NoSuchEntityException
+ */
+ private function getCallbackUrl($websiteId)
{
- $this->configWriter->save(
- "pagarme_pagarme/global/secret_key",
- null,
- 'default',
- 0
- );
-
- $this->configWriter->save(
- "pagarme_pagarme/global/public_key",
- null,
- 'default',
- 0
- );
+ $baseUrl = $this->storeManager->getStore()->getBaseUrl();
+ $callbackUrl = $baseUrl . "rest/V1/pagarme/hub/command";
- $this->configWriter->save(
- "pagarme_pagarme/global/secret_key_test",
- null,
- 'default',
- 0
- );
+ if (!empty($websiteId)) {
+ $callbackUrl .= "?websiteId=" . $websiteId;
+ }
- $this->configWriter->save(
- "pagarme_pagarme/global/public_key_test",
- null,
- 'default',
- 0
- );
- $this->configWriter->save(
- "pagarme_pagarme/hub/account_id",
- null,
- 'default',
- 0
- );
+ return $callbackUrl;
+ }
- $this->configWriter->save(
- "pagarme_pagarme/hub/merchant_id",
- null,
- 'default',
- 0
- );
+ /**
+ * @return string
+ * @throws NoSuchEntityException
+ */
+ private function getWebHookkUrl()
+ {
+ $baseUrl = $this->storeManager->getStore()->getBaseUrl();
+ return $baseUrl . "rest/V1/pagarme/webhook";
}
private function updateStoreFields($websiteId)
{
$currentConfiguration = Magento2CoreSetup::getModuleConfiguration();
+ $scope = $this->getScopeName();
$this->configWriter->save(
"pagarme_pagarme/hub/install_id",
$currentConfiguration->getHubInstallId()->getValue(),
- 'websites',
+ $scope,
$websiteId
);
$this->configWriter->save(
"pagarme_pagarme/hub/environment",
$currentConfiguration->getHubEnvironment()->getValue(),
- 'websites',
+ $scope,
$websiteId
);
$this->configWriter->save(
"pagarme_pagarme/global/secret_key",
$currentConfiguration->getSecretKey()->getValue(),
- 'websites',
+ $scope,
$websiteId
);
$this->configWriter->save(
"pagarme_pagarme/global/public_key",
$currentConfiguration->getPublicKey()->getValue(),
- 'websites',
+ $scope,
$websiteId
);
$this->configWriter->save(
"pagarme_pagarme/hub/account_id",
$currentConfiguration->getAccountId()->getValue(),
- 'websites',
+ $scope,
$websiteId
);
$this->configWriter->save(
"pagarme_pagarme/hub/merchant_id",
$currentConfiguration->getMerchantId()->getValue(),
- 'websites',
+ $scope,
$websiteId
);
$this->configWriter->save(
"pagarme_pagarme/global/test_mode",
0,
- 'websites',
+ $scope,
$websiteId
);
$this->configWriter->save(
"pagarme_pagarme/global/secret_key_test",
null,
- 'websites',
+ $scope,
$websiteId
);
$this->configWriter->save(
"pagarme_pagarme/global/public_key_test",
null,
- 'websites',
+ $scope,
$websiteId
);
- if ($this->allWebsitesIntegrated($websiteId)) {
- $this->removeDefaultConfigKeys();
- }
-
$this->cacheManager->clean(['config']);
}
}
diff --git a/Model/Account.php b/Model/Account.php
index f0950ce3..f6aab4e2 100644
--- a/Model/Account.php
+++ b/Model/Account.php
@@ -9,11 +9,11 @@
use Magento\Framework\App\RequestInterface;
use Magento\Framework\Exception\LocalizedException;
use Magento\Framework\Exception\NoSuchEntityException;
-use Magento\Store\Model\ScopeInterface;
use Magento\Store\Model\StoreManagerInterface;
use Pagarme\Core\Kernel\Aggregates\Configuration;
use Pagarme\Core\Middle\Model\Account as AccountMiddle;
use Pagarme\Pagarme\Concrete\Magento2CoreSetup;
+use Pagarme\Pagarme\Controller\Adminhtml\Hub\Index as HubControllerIndex;
use Pagarme\Pagarme\Model\Api\HubCommand;
use Pagarme\Pagarme\Service\AccountService;
use Psr\Log\LoggerInterface;
@@ -70,6 +70,11 @@ class Account
*/
protected $pagarmeConfigProvider;
+ /**
+ * @var HubControllerIndex
+ */
+ protected $hubControllerIndex;
+
/**
* @param WriterInterface $configWriter
* @param StoreManagerInterface $storeManager
@@ -78,17 +83,21 @@ class Account
* @param CollectionFactory $configCollectionFactory
* @param LoggerInterface $logger
* @param Session $session
+ * @param PagarmeConfigProvider $pagarmeConfigProvider
+ * @param HubControllerIndex $hubControllerIndex
*/
public function __construct(
- WriterInterface $configWriter,
+ WriterInterface $configWriter,
StoreManagerInterface $storeManager,
- AccountService $accountService,
- HubCommand $hubCommand,
- CollectionFactory $configCollectionFactory,
- LoggerInterface $logger,
- Session $session,
- PagarmeConfigProvider $pagarmeConfigProvider
- ) {
+ AccountService $accountService,
+ HubCommand $hubCommand,
+ CollectionFactory $configCollectionFactory,
+ LoggerInterface $logger,
+ Session $session,
+ PagarmeConfigProvider $pagarmeConfigProvider,
+ HubControllerIndex $hubControllerIndex
+ )
+ {
$this->configWriter = $configWriter;
$this->storeManager = $storeManager;
$this->accountService = $accountService;
@@ -97,11 +106,14 @@ public function __construct(
$this->logger = $logger;
$this->session = $session;
$this->pagarmeConfigProvider = $pagarmeConfigProvider;
+ $this->hubControllerIndex = $hubControllerIndex;
}
/**
* @param mixed $website
* @return void
+ * @throws LocalizedException
+ * @throws NoSuchEntityException
*/
public function validateDashSettings($website)
{
@@ -119,7 +131,7 @@ public function validateDashSettings($website)
$this->configWriter->save(
PagarmeConfigProvider::PATH_DASH_ERRORS,
json_encode($account->getErrors()),
- ScopeInterface::SCOPE_WEBSITES,
+ $this->hubControllerIndex->getScopeName(),
$website
);
$this->savePaymentTypes($account, $website);
@@ -145,9 +157,8 @@ public function saveAccountIdFromWebhook($account)
$this->configWriter->save(
PagarmeConfigProvider::PATH_ACCOUNT_ID,
$account['id'],
- ScopeInterface::SCOPE_WEBSITES,
- $this->storeManager->getStore()
- ->getWebsiteId()
+ $this->hubControllerIndex->getScopeName(),
+ $this->storeManager->getStore()->getWebsiteId()
);
}
@@ -161,7 +172,7 @@ public function getDashSettingsErrors()
$this->initializeConfig();
$collection = $this->configCollectionFactory->create();
$collection->addFieldToFilter('path', ['eq' => PagarmeConfigProvider::PATH_DASH_ERRORS]);
- $collection->addFieldToFilter('scope', ['eq' => ScopeInterface::SCOPE_WEBSITES]);
+ $collection->addFieldToFilter('scope', ['eq' => $this->hubControllerIndex->getScopeName()]);
$collection->addFieldToFilter('scope_id', ['eq' => $this->session->getWebsiteId()]);
if ($collection->count() === 0) {
@@ -192,7 +203,7 @@ public function getPaymentType(string $paymentName, bool $gateway = true)
: PagarmeConfigProvider::PATH_IS_PAYMENT_PSP_TYPE;
$collection = $this->configCollectionFactory->create();
$collection->addFieldToFilter('path', ['eq' => sprintf($paymentType, $paymentName)]);
- $collection->addFieldToFilter('scope', ['eq' => ScopeInterface::SCOPE_WEBSITES]);
+ $collection->addFieldToFilter('scope', ['eq' => $this->hubControllerIndex->getScopeName()]);
$collection->addFieldToFilter('scope_id', ['eq' => $this->session->getWebsiteId()]);
if ($collection->count() === 0) {
@@ -287,7 +298,7 @@ private function initializeConfig($website = null)
$websiteId = $this->session->getWebsiteId();
}
- if (!$websiteId) {
+ if (!$websiteId && $websiteId !== 0) {
$websiteId = $this->storeManager->getStore()
->getWebsiteId();
}
@@ -374,7 +385,7 @@ private function saveConfig($path, $value, $website)
$this->configWriter->save(
$path,
$value,
- ScopeInterface::SCOPE_WEBSITES,
+ $this->hubControllerIndex->getScopeName(),
$website
);
}
diff --git a/Model/Api/HubCommand.php b/Model/Api/HubCommand.php
index 4fdceddb..8d445a0d 100644
--- a/Model/Api/HubCommand.php
+++ b/Model/Api/HubCommand.php
@@ -3,6 +3,7 @@
namespace Pagarme\Pagarme\Model\Api;
use Magento\Framework\App\Cache\Manager;
+use Magento\Framework\App\Cache\Type\Config;
use Magento\Framework\App\Config\Storage\WriterInterface;
use Magento\Framework\Webapi\Exception as MagentoException;
use Magento\Framework\Webapi\Rest\Request;
@@ -10,6 +11,7 @@
use Pagarme\Core\Hub\Services\HubIntegrationService;
use Pagarme\Pagarme\Api\HubCommandInterface;
use Pagarme\Pagarme\Concrete\Magento2CoreSetup;
+use Pagarme\Pagarme\Controller\Adminhtml\Hub\Index as HubControllerIndex;
class HubCommand implements HubCommandInterface
{
@@ -38,18 +40,29 @@ class HubCommand implements HubCommandInterface
*/
protected $storeManager;
+ /**
+ * @var HubControllerIndex
+ */
+ private $hubControllerIndex;
+
public function __construct(
Request $request,
WriterInterface $configWriter,
Manager $cacheManager,
- StoreManagerInterface $storeManager
+ StoreManagerInterface $storeManager,
+ HubControllerIndex $hubControllerIndex
) {
$this->request = $request;
$this->configWriter = $configWriter;
$this->cacheManager = $cacheManager;
$this->storeManager = $storeManager;
+ $this->hubControllerIndex = $hubControllerIndex;
}
+ /**
+ * @throws MagentoException
+ * @throws \Exception
+ */
public function execute()
{
$params = json_decode(
@@ -57,13 +70,8 @@ public function execute()
);
$paramsFromUrl = $this->request->getParams();
- $this->websiteId = isset($paramsFromUrl['websiteId'])
- ? $paramsFromUrl['websiteId']
- : $this->storeManager->getDefaultStoreView()->getWebsiteId();
+ $this->websiteId = $paramsFromUrl['websiteId'] ?? 0;
- $storeId = $this->storeManager->getWebsite($this->websiteId)
- ->getDefaultStore()->getId();
- $this->storeManager->setCurrentStore($storeId);
Magento2CoreSetup::bootstrap();
$hubIntegrationService = new HubIntegrationService();
@@ -83,79 +91,73 @@ public function execute()
return "Command $params->command executed successfully";
}
- $commandMessage = $this->$command();
- return $commandMessage;
+ return $this->$command();
}
public function uninstallCommand()
{
- if (!$this->websiteId) {
- $this->websiteId = 1;
+ $scope = $this->hubControllerIndex->getScopeName();
+ $websiteId = $this->websiteId ?? Magento2CoreSetup::getCurrentStoreId();
+
+ if (!$websiteId) {
+ $websiteId = 0;
}
- $this->configWriter->save(
+
+ $this->configWriter->delete(
"pagarme_pagarme/hub/install_id",
- null,
- 'websites',
- $this->websiteId
+ $scope,
+ $websiteId
);
- $this->configWriter->save(
+ $this->configWriter->delete(
"pagarme_pagarme/hub/environment",
- null,
- 'websites',
- $this->websiteId
+ $scope,
+ $websiteId
);
- $this->configWriter->save(
+ $this->configWriter->delete(
"pagarme_pagarme/global/secret_key",
- null,
- 'websites',
- $this->websiteId
+ $scope,
+ $websiteId
);
- $this->configWriter->save(
+ $this->configWriter->delete(
"pagarme_pagarme/global/public_key",
- null,
- 'websites',
- $this->websiteId
+ $scope,
+ $websiteId
);
- $this->configWriter->save(
+ $this->configWriter->delete(
"pagarme_pagarme/global/secret_key_test",
- null,
- 'websites',
- $this->websiteId
+ $scope,
+ $websiteId
);
- $this->configWriter->save(
+ $this->configWriter->delete(
"pagarme_pagarme/global/public_key_test",
- null,
- 'websites',
- $this->websiteId
+ $scope,
+ $websiteId
);
- $this->configWriter->save(
+ $this->configWriter->delete(
"pagarme_pagarme/hub/account_id",
- null,
- 'websites',
- $this->websiteId
+ $scope,
+ $websiteId
);
- $this->configWriter->save(
+ $this->configWriter->delete(
"pagarme_pagarme/hub/merchant_id",
- null,
- 'websites',
- $this->websiteId
+ $scope,
+ $websiteId
);
- $this->configWriter->save(
+ $this->configWriter->delete(
"pagarme_pagarme/hub/account_errors",
- null,
- 'websites',
- $this->websiteId
+ $scope,
+ $websiteId
);
- $this->cacheManager->clean(['config']);
+ $this->cacheManager->clean([Config::TYPE_IDENTIFIER]);
return "Hub uninstalled successfully";
}
diff --git a/Model/Notifications.php b/Model/Notifications.php
index 28a946b2..a55ffbc9 100644
--- a/Model/Notifications.php
+++ b/Model/Notifications.php
@@ -60,9 +60,11 @@ class Notifications extends Message
* @param Registry $registry
* @param Account $account
* @param HubIntegration $hubIntegration
+ * @param UrlInterface $urlInterface
* @param AbstractResource|null $resource
* @param AbstractDb|null $resourceCollection
* @param array $data
+ * @throws NoSuchEntityException
*/
public function __construct(
ConfigInterface $config,
@@ -271,18 +273,7 @@ private function addDashSettingsMessages()
*/
private function buildDashLink(string $label, string $dashPage = '')
{
- if (!$this->account->hasMerchantAndAccountIds()) {
- return $label;
- }
-
- $dashSettings = !empty($dashPage) ? "settings/{$dashPage}/" : '';
- $url = $this->account->getDashUrl() . $dashSettings;
-
- return sprintf(
- '%s',
- $url,
- $label
- );
+ return $label;
}
/**
diff --git a/Observer/DashConfigValidatorObserver.php b/Observer/DashConfigValidatorObserver.php
index f33b2c1f..41e970fa 100644
--- a/Observer/DashConfigValidatorObserver.php
+++ b/Observer/DashConfigValidatorObserver.php
@@ -4,8 +4,10 @@
use Magento\Framework\Event\Observer;
use Magento\Framework\Event\ObserverInterface;
+use Magento\Framework\Exception\LocalizedException;
use Magento\Framework\Exception\NoSuchEntityException;
use Magento\Store\Model\StoreManagerInterface;
+use Pagarme\Pagarme\Controller\Adminhtml\Hub\Index as HubControllerIndex;
use Pagarme\Pagarme\Model\Account;
class DashConfigValidatorObserver implements ObserverInterface
@@ -20,33 +22,45 @@ class DashConfigValidatorObserver implements ObserverInterface
*/
protected $storeManager;
+ /**
+ * @var HubControllerIndex
+ */
+ protected $hubControllerIndex;
+
/**
* @param Account $account
* @param StoreManagerInterface $storeManager
+ * @param HubControllerIndex $hubControllerIndex
*/
public function __construct(
- Account $account,
- StoreManagerInterface $storeManager
- ) {
+ Account $account,
+ StoreManagerInterface $storeManager,
+ HubControllerIndex $hubControllerIndex
+ )
+ {
$this->account = $account;
$this->storeManager = $storeManager;
+ $this->hubControllerIndex = $hubControllerIndex;
}
/**
* @param Observer $observer
* @return $this
- * @throws NoSuchEntityException
+ * @throws NoSuchEntityException|LocalizedException
*/
public function execute(Observer $observer)
{
- $section = $observer->getRequest()
- ->getParam('section');
+ $section = $observer->getRequest()->getParam('section');
if ($section !== 'payment') {
return $this;
}
- $website = $observer->getRequest()
- ->getParam('website', $this->storeManager->getStore()->getWebsiteId());
+ $scopeUrl = $this->hubControllerIndex->getScopeUrl() ?? 'default';
+ $websiteCode = $this->hubControllerIndex->getScopeUrl() ? $this->storeManager->getWebsite()->getId() : 0;
+ $website = $observer->getRequest()->getParam(
+ $scopeUrl,
+ $websiteCode
+ );
$this->account->validateDashSettings($website);
return $this;
diff --git a/Observer/HubIntegrationObserver.php b/Observer/HubIntegrationObserver.php
new file mode 100644
index 00000000..8a15fd71
--- /dev/null
+++ b/Observer/HubIntegrationObserver.php
@@ -0,0 +1,48 @@
+hubCommand = $hubCommand;
+ }
+
+ /**
+ * @param Observer $observer
+ * @return void
+ */
+ public function execute(Observer $observer)
+ {
+ $configData = $observer->getData('event')->getData('configData');
+
+ if ($configData[ScopeInterface::SCOPE_WEBSITE] === null) {
+ return;
+ }
+
+ $pagarmeGlobalFields = $configData['groups']['pagarme_pagarme']['groups']['pagarme_pagarme_global']['fields'];
+ $integrationUseDefault = 0;
+
+ if (array_key_exists('hub_integration', $pagarmeGlobalFields)) {
+ $integrationUseDefault = $pagarmeGlobalFields['hub_integration']['inherit'];
+ }
+
+ if ($integrationUseDefault === '1') {
+ $this->hubCommand->uninstallCommand();
+ }
+ }
+}
diff --git a/etc/adminhtml/system/global.xml b/etc/adminhtml/system/global.xml
index f2f6b03c..6fc46ead 100644
--- a/etc/adminhtml/system/global.xml
+++ b/etc/adminhtml/system/global.xml
@@ -3,9 +3,10 @@
-
+
Pagarme\Pagarme\Block\Adminhtml\System\Config\Form\Field\HubIntegration
+ pagarme_pagarme/hub/install_id
diff --git a/etc/events.xml b/etc/events.xml
index 18e83e56..60172a18 100644
--- a/etc/events.xml
+++ b/etc/events.xml
@@ -1,75 +1,87 @@
-
+
-
+
-
+
-
+
-
+
-
+
-
+
-
+
-
-
+
+
-
+
-
+
-
+
+
+
+
-
+
-
+
-
+
-
+ instance="Pagarme\Pagarme\Observer\OrderCancelAfter"/>
-
+ instance="Pagarme\Pagarme\Observer\OrderCancelAfter"/>
-
+ instance="Pagarme\Pagarme\Observer\CartAddProductAfterObserver"/>
-
+ instance="Pagarme\Pagarme\Observer\UpdateProductPlanObserver"/>
-
+ instance="Pagarme\Pagarme\Observer\CustomerLogin"/>
-
-
+
diff --git a/view/adminhtml/layout/adminhtml_system_config_edit.xml b/view/adminhtml/layout/adminhtml_system_config_edit.xml
index 998a8f56..06c5e5db 100644
--- a/view/adminhtml/layout/adminhtml_system_config_edit.xml
+++ b/view/adminhtml/layout/adminhtml_system_config_edit.xml
@@ -5,6 +5,7 @@
+
diff --git a/view/adminhtml/web/css/integration_buttons.css b/view/adminhtml/web/css/integration_buttons.css
index 59b87f70..20f803b9 100644
--- a/view/adminhtml/web/css/integration_buttons.css
+++ b/view/adminhtml/web/css/integration_buttons.css
@@ -1,4 +1,8 @@
-#pagarme-hub-button, #pagarme-dash-button {
+#row_payment_other_pagarme_pagarme_pagarme_pagarme_global_hub_integration .control-value {
+ display: none;
+}
+
+a.pagarme-integration-button, #pagarme-dash-button {
background-color: #65a300;
border-color: #65a300;
border-radius: 2px;
@@ -17,7 +21,7 @@
color: #fff;
user-select: none;
transition: background-color .2s ease-in-out, border-color .2s ease-in-out;
- margin: 0 1rem 1rem 0;
+ margin: 0 1rem 0 0;
}
#pagarme-dash-button {
@@ -27,18 +31,35 @@
text-transform: none;
}
-#pagarme-hub-button:hover, #pagarme-hub-button:active, #pagarme-hub-button:focus {
+a.pagarme-integration-button.hidden {
+ display: none !important;
+}
+
+.is-disabled a.pagarme-integration-button {
+ background-color: #e9e9e9;
+ border-color: #adadad;
+ color: #303030;
+ pointer-events: none;
+ touch-action: none;
+ cursor: not-allowed;
+ opacity: 0.5;
+}
+
+a.pagarme-integration-button:hover, a.pagarme-integration-button:active, a.pagarme-integration-button:focus {
background-color: #7da300;
border-color: #7da300;
+ color: #fff;
+ text-decoration: none;
}
#pagarme-dash-button:hover, #pagarme-dash-button:active, #pagarme-dash-button:focus {
background-color: #dbdbdb;
}
-#pagarme-hub-button:after {
+#pagarme-integrate-button:after,
+#pagarme-view-integration-button:after{
content: "";
- background: url("");
+ background-image: url("");
background-size: 16px 16px;
background-repeat: no-repeat;
display: inline-block;
diff --git a/view/adminhtml/web/js/global.js b/view/adminhtml/web/js/global.js
new file mode 100644
index 00000000..88bf0751
--- /dev/null
+++ b/view/adminhtml/web/js/global.js
@@ -0,0 +1,79 @@
+require([
+ "jquery",
+ "jquery/ui",
+], function ($) {
+ "use strict";
+ $(document).ready(function () {
+ const
+ integrationButtonsRow = $('#row_payment_other_pagarme_pagarme_pagarme_pagarme_global_hub_integration'),
+ integrationButtons = $('a.pagarme-integration-button'),
+ integrateButton = $('#pagarme-integrate-button'),
+ viewIntegrationButton = $('#pagarme-view-integration-button'),
+ dashButton = $('#pagarme-dash-button'),
+ integrationUseDefault = $('#payment_other_pagarme_pagarme_pagarme_pagarme_global_hub_integration_inherit'),
+ integratedScope = $('[data-pagarme-integration-scope]').attr('data-pagarme-integration-scope'),
+ hasIntegration =
+ $('#row_payment_other_pagarme_pagarme_pagarme_pagarme_global_hub_integration .control-value')
+ .html() !== '',
+ disabledClass = 'is-disabled',
+ hiddenClass = 'hidden';
+
+ if (integrationUseDefault.is(':checked') && hasIntegration) {
+ disableButtons();
+ }
+
+ integrationButtons.on('click', function(event) {
+ const isDisabled = integrationButtonsRow.hasClass(disabledClass);
+
+ if (isDisabled) {
+ event.preventDefault();
+ }
+ });
+
+ integrationUseDefault.on('change', function() {
+ if ($(this).is(':checked')) {
+ disableButtons();
+ showIntegratedButtons();
+ return;
+ }
+
+ enableButtons();
+ hideIntegratedButtons();
+ })
+
+ function disableButtons() {
+ if (!hasIntegration) {
+ return;
+ }
+
+ integrationButtonsRow.addClass(disabledClass);
+ }
+
+ function enableButtons() {
+ integrationButtonsRow.removeClass(disabledClass);
+ }
+
+ function hideIntegratedButtons() {
+ if (integratedScope !== 'default') {
+ return;
+ }
+
+ viewIntegrationButton.addClass(hiddenClass);
+ dashButton.addClass(hiddenClass);
+ integrateButton.removeClass(hiddenClass);
+ }
+
+ function showIntegratedButtons() {
+ if (
+ (integratedScope === 'default' && !integrationUseDefault.is(':checked'))
+ || !hasIntegration
+ ) {
+ return;
+ }
+
+ integrateButton.addClass(hiddenClass);
+ viewIntegrationButton.removeClass(hiddenClass);
+ dashButton.removeClass(hiddenClass);
+ }
+ });
+});
|