diff --git a/.gitattributes b/.gitattributes
index 3b71983..cc3c401 100644
--- a/.gitattributes
+++ b/.gitattributes
@@ -6,4 +6,5 @@
# Exclude specific directories
.github export-ignore
docs export-ignore
-docker export-ignore
\ No newline at end of file
+docker export-ignore
+bin export-ignore
\ No newline at end of file
diff --git a/Console/Configure.php b/Console/Configure.php
new file mode 100644
index 0000000..c9940bc
--- /dev/null
+++ b/Console/Configure.php
@@ -0,0 +1,268 @@
+initInstance();
+ }
+ /**
+ * Initialize triggerreport command
+ *
+ * @return void
+ */
+ protected function configure()
+ {
+ $inputOptions = [
+
+ ];
+ $this->setName(self::NAME)
+ ->setDescription('Quickly set sequra configuration')
+ ->addOption(
+ self::INPUT_KEY_MERCHANT_REF,
+ null,
+ InputOption::VALUE_OPTIONAL,
+ 'Merchant reference'
+ )
+ ->addOption(
+ self::INPUT_KEY_USERNAME,
+ null,
+ InputOption::VALUE_OPTIONAL,
+ 'Username'
+ )
+ ->addOption(
+ self::INPUT_KEY_ASSETS_KEY,
+ null,
+ InputOption::VALUE_OPTIONAL,
+ 'Assets key'
+ )
+ ->addOption(
+ self::INPUT_KEY_ENDPOINT,
+ null,
+ InputOption::VALUE_OPTIONAL,
+ 'Endpoint'
+ )
+ ->addOption(
+ self::INPUT_KEY_PASSWORD,
+ null,
+ InputOption::VALUE_OPTIONAL,
+ 'Password'
+ );
+ parent::configure();
+ }
+
+ /**
+ * Execute command.
+ *
+ * @param InputInterface $input InputInterface
+ * @param OutputInterface $output OutputInterface
+ *
+ * @return void
+ * @SuppressWarnings(PHPMD.UnusedFormalParameter)
+ */
+ protected function execute(InputInterface $input, OutputInterface $output)
+ {
+ $this->saveConnectionData(
+ $input->getOption(self::INPUT_KEY_ENDPOINT),
+ $input->getOption(self::INPUT_KEY_USERNAME),
+ $input->getOption(self::INPUT_KEY_PASSWORD)
+ );
+ $this->saveCountriesConfig(
+ $this->getSellingCountriesService()->getSellingCountries(),
+ $input->getOption(self::INPUT_KEY_MERCHANT_REF)
+ );
+ $generalSettings = new GeneralSettings(
+ false,
+ true,
+ [],
+ [],
+ []
+ );
+ $this->getGeneralSettingsService()->saveGeneralSettings($generalSettings);
+ $this->saveWidgetSettings($input->getOption(self::INPUT_KEY_ASSETS_KEY));
+ return 0;
+ }
+
+ /**
+ * @param string $endpoint
+ * @param string $username
+ * @param string $password
+ *
+ * @return void
+ *
+ * @throws InvalidEnvironmentException
+ */
+ private function saveConnectionData(string $endpoint, string $username, string $password)
+ {
+ $connectionData = new ConnectionData(
+ $endpoint === 'https://sandbox.sequrapi.com/orders' ? BaseProxy::TEST_MODE : BaseProxy::LIVE_MODE,
+ '',
+ new AuthorizationCredentials($username, $password)
+ );
+ $this->getConnectionService()->saveConnectionData($connectionData);
+ }
+ /**
+ * @return ConnectionService
+ */
+ private function getConnectionService(): ConnectionService
+ {
+ if ($this->connectionService === null) {
+ $this->connectionService = ServiceRegister::getService(ConnectionService::class);
+ }
+
+ return $this->connectionService;
+ }
+ /**
+ * @return GeneralSettingsService
+ */
+ private function getGeneralSettingsService(): GeneralSettingsService
+ {
+ if ($this->generalSettingsService === null) {
+ $this->generalSettingsService = ServiceRegister::getService(GeneralSettingsService::class);
+ }
+
+ return $this->generalSettingsService;
+ }
+ /**
+ * @param SellingCountry[] $sellingCountries
+ * @param string $merchantId
+ *
+ * @return void
+ *
+ * @throws EmptyCountryConfigurationParameterException
+ * @throws InvalidCountryCodeForConfigurationException
+ */
+ private function saveCountriesConfig(array $sellingCountries, string $merchantId)
+ {
+ $countryConfiguration = [];
+ foreach ($sellingCountries as $country) {
+ $countryConfiguration[] = new CountryConfiguration($country->getCode(), $merchantId);
+ }
+
+ $this->getCountryConfigService()->saveCountryConfiguration($countryConfiguration);
+ }
+ /**
+ * @return CountryConfigurationService
+ */
+ private function getCountryConfigService(): CountryConfigurationService
+ {
+ if ($this->countryConfigService === null) {
+ $this->countryConfigService = ServiceRegister::getService(CountryConfigurationService::class);
+ }
+
+ return $this->countryConfigService;
+ }
+ /**
+ * @return SellingCountriesService
+ */
+ private function getSellingCountriesService(): SellingCountriesService
+ {
+ if ($this->sellingCountriesService === null) {
+ $this->sellingCountriesService = ServiceRegister::getService(SellingCountriesService::class);
+ }
+
+ return $this->sellingCountriesService;
+ }
+
+ /**
+ * @param string $assetsKey
+ *
+ * @return void
+ *
+ * @throws HttpRequestException
+ * @throws Exception
+ */
+ private function saveWidgetSettings(string $assetsKey)
+ {
+ if (!$this->getWidgetSettingsService()->isAssetsKeyValid($assetsKey)) {
+ return;
+ }
+
+ $widgetSettings = new WidgetSettings(false, $assetsKey);
+ $this->getWidgetSettingsService()->setWidgetSettings($widgetSettings);
+ }
+ /**
+ * @return WidgetSettingsService
+ */
+ private function getWidgetSettingsService(): WidgetSettingsService
+ {
+ return ServiceRegister::getService(WidgetSettingsService::class);
+ }
+}
\ No newline at end of file
diff --git a/composer.json b/composer.json
index f287105..f2dcdd5 100644
--- a/composer.json
+++ b/composer.json
@@ -8,7 +8,7 @@
"pagos",
"magento2"
],
- "version": "2.5.0.4",
+ "version": "2.5.1",
"license": "MIT",
"authors": [
{
diff --git a/composer.lock b/composer.lock
index deeb939..6a313ce 100644
--- a/composer.lock
+++ b/composer.lock
@@ -4,7 +4,7 @@
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
"This file is @generated automatically"
],
- "content-hash": "02abb91b23c5de31dbfaeecaddf6aeb7",
+ "content-hash": "0831f83fa70e54df96f0bc90bbb725fe",
"packages": [
{
"name": "sequra/integration-core",
@@ -250,22 +250,22 @@
},
{
"name": "phpcsstandards/phpcsutils",
- "version": "1.0.10",
+ "version": "1.0.12",
"source": {
"type": "git",
"url": "https://github.com/PHPCSStandards/PHPCSUtils.git",
- "reference": "51609a5b89f928e0c463d6df80eb38eff1eaf544"
+ "reference": "87b233b00daf83fb70f40c9a28692be017ea7c6c"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/PHPCSStandards/PHPCSUtils/zipball/51609a5b89f928e0c463d6df80eb38eff1eaf544",
- "reference": "51609a5b89f928e0c463d6df80eb38eff1eaf544",
+ "url": "https://api.github.com/repos/PHPCSStandards/PHPCSUtils/zipball/87b233b00daf83fb70f40c9a28692be017ea7c6c",
+ "reference": "87b233b00daf83fb70f40c9a28692be017ea7c6c",
"shasum": ""
},
"require": {
"dealerdirect/phpcodesniffer-composer-installer": "^0.4.1 || ^0.5 || ^0.6.2 || ^0.7 || ^1.0",
"php": ">=5.4",
- "squizlabs/php_codesniffer": "^3.9.0 || 4.0.x-dev@dev"
+ "squizlabs/php_codesniffer": "^3.10.0 || 4.0.x-dev@dev"
},
"require-dev": {
"ext-filter": "*",
@@ -334,20 +334,20 @@
"type": "open_collective"
}
],
- "time": "2024-03-17T23:44:50+00:00"
+ "time": "2024-05-20T13:34:27+00:00"
},
{
"name": "phpstan/phpstan",
- "version": "1.10.66",
+ "version": "1.11.7",
"source": {
"type": "git",
"url": "https://github.com/phpstan/phpstan.git",
- "reference": "94779c987e4ebd620025d9e5fdd23323903950bd"
+ "reference": "52d2bbfdcae7f895915629e4694e9497d0f8e28d"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/phpstan/phpstan/zipball/94779c987e4ebd620025d9e5fdd23323903950bd",
- "reference": "94779c987e4ebd620025d9e5fdd23323903950bd",
+ "url": "https://api.github.com/repos/phpstan/phpstan/zipball/52d2bbfdcae7f895915629e4694e9497d0f8e28d",
+ "reference": "52d2bbfdcae7f895915629e4694e9497d0f8e28d",
"shasum": ""
},
"require": {
@@ -390,13 +390,9 @@
{
"url": "https://github.com/phpstan",
"type": "github"
- },
- {
- "url": "https://tidelift.com/funding/github/packagist/phpstan/phpstan",
- "type": "tidelift"
}
],
- "time": "2024-03-28T16:17:31+00:00"
+ "time": "2024-07-06T11:17:41+00:00"
},
{
"name": "rector/rector",
@@ -456,16 +452,16 @@
},
{
"name": "squizlabs/php_codesniffer",
- "version": "3.9.1",
+ "version": "3.10.1",
"source": {
"type": "git",
"url": "https://github.com/PHPCSStandards/PHP_CodeSniffer.git",
- "reference": "267a4405fff1d9c847134db3a3c92f1ab7f77909"
+ "reference": "8f90f7a53ce271935282967f53d0894f8f1ff877"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/PHPCSStandards/PHP_CodeSniffer/zipball/267a4405fff1d9c847134db3a3c92f1ab7f77909",
- "reference": "267a4405fff1d9c847134db3a3c92f1ab7f77909",
+ "url": "https://api.github.com/repos/PHPCSStandards/PHP_CodeSniffer/zipball/8f90f7a53ce271935282967f53d0894f8f1ff877",
+ "reference": "8f90f7a53ce271935282967f53d0894f8f1ff877",
"shasum": ""
},
"require": {
@@ -532,20 +528,20 @@
"type": "open_collective"
}
],
- "time": "2024-03-31T21:03:09+00:00"
+ "time": "2024-05-22T21:24:41+00:00"
},
{
"name": "webonyx/graphql-php",
- "version": "v15.11.1",
+ "version": "v15.12.5",
"source": {
"type": "git",
"url": "https://github.com/webonyx/graphql-php.git",
- "reference": "ab4ff2719b101dc3bfc3aaaf800edc21a98c56dc"
+ "reference": "7bcd31d1dcf67781ed5cb493b22c519c539c05e6"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/webonyx/graphql-php/zipball/ab4ff2719b101dc3bfc3aaaf800edc21a98c56dc",
- "reference": "ab4ff2719b101dc3bfc3aaaf800edc21a98c56dc",
+ "url": "https://api.github.com/repos/webonyx/graphql-php/zipball/7bcd31d1dcf67781ed5cb493b22c519c539c05e6",
+ "reference": "7bcd31d1dcf67781ed5cb493b22c519c539c05e6",
"shasum": ""
},
"require": {
@@ -558,15 +554,15 @@
"amphp/http-server": "^2.1",
"dms/phpunit-arraysubset-asserts": "dev-master",
"ergebnis/composer-normalize": "^2.28",
- "friendsofphp/php-cs-fixer": "3.51.0",
+ "friendsofphp/php-cs-fixer": "3.59.3",
"mll-lab/php-cs-fixer-config": "^5",
"nyholm/psr7": "^1.5",
"phpbench/phpbench": "^1.2",
"phpstan/extension-installer": "^1.1",
- "phpstan/phpstan": "1.10.59",
- "phpstan/phpstan-phpunit": "1.3.16",
- "phpstan/phpstan-strict-rules": "1.5.2",
- "phpunit/phpunit": "^9.5 || ^10",
+ "phpstan/phpstan": "1.11.5",
+ "phpstan/phpstan-phpunit": "1.4.0",
+ "phpstan/phpstan-strict-rules": "1.6.0",
+ "phpunit/phpunit": "^9.5 || ^10.5.21",
"psr/http-message": "^1 || ^2",
"react/http": "^1.6",
"react/promise": "^2.0 || ^3.0",
@@ -598,7 +594,7 @@
],
"support": {
"issues": "https://github.com/webonyx/graphql-php/issues",
- "source": "https://github.com/webonyx/graphql-php/tree/v15.11.1"
+ "source": "https://github.com/webonyx/graphql-php/tree/v15.12.5"
},
"funding": [
{
@@ -606,14 +602,12 @@
"type": "open_collective"
}
],
- "time": "2024-03-11T10:21:05+00:00"
+ "time": "2024-06-23T11:30:58+00:00"
}
],
"aliases": [],
"minimum-stability": "stable",
- "stability-flags": {
- "sequra/integration-core": 20
- },
+ "stability-flags": [],
"prefer-stable": false,
"prefer-lowest": false,
"platform": {
@@ -621,5 +615,5 @@
"ext-json": "*"
},
"platform-dev": [],
- "plugin-api-version": "2.2.0"
+ "plugin-api-version": "2.6.0"
}
diff --git a/etc/di.xml b/etc/di.xml
index aeb6006..7b6a92b 100644
--- a/etc/di.xml
+++ b/etc/di.xml
@@ -143,6 +143,15 @@
+
+
+
+
+ - Sequra\Core\Console\Configure
+
+
+
+
diff --git a/etc/module.xml b/etc/module.xml
index 135e592..fe5d5cf 100644
--- a/etc/module.xml
+++ b/etc/module.xml
@@ -5,7 +5,7 @@
*/
-->
-
+