From 71a42daacbe83a71e629258bb7daec4e201974fd Mon Sep 17 00:00:00 2001 From: Szymon Kostrubiec Date: Fri, 26 Jul 2024 10:12:46 +0200 Subject: [PATCH] OP-377 - Apply ECS fixes, update ECS config and update dependencies --- composer.json | 1 + ecs.php | 21 +---- src/Action/CaptureAction.php | 11 ++- src/Action/ConvertPaymentAction.php | 9 +- src/Action/NotifyAction.php | 7 ++ src/Action/StatusAction.php | 11 ++- src/BitBagMercanetBnpParibasPlugin.php | 7 ++ src/Bridge/MercanetBnpParibasBridge.php | 7 ++ .../MercanetBnpParibasBridgeInterface.php | 7 ++ .../BitBagMercanetBnpParibasExtension.php | 7 ++ src/DependencyInjection/Configuration.php | 7 ++ ...anetBnpParibasGatewayConfigurationType.php | 7 ++ src/Legacy/Mercanet.php | 91 ++++++++++--------- src/Legacy/SimplePayment.php | 7 ++ src/MercanetBnpParibasGatewayFactory.php | 7 ++ tests/Application/config/bootstrap.php | 9 +- tests/Application/config/bundles.php | 9 ++ .../config/sylius/1.13/bundles.php | 7 ++ tests/Application/public/index.php | 7 ++ tests/Behat/Context/Setup/ChannelContext.php | 7 ++ .../Setup/MercanetBnpParibasContext.php | 7 ++ .../Admin/ManagingPaymentMethodsContext.php | 7 ++ .../Ui/Shop/MercanetBnpParibasContext.php | 11 ++- .../Page/Admin/PaymentMethod/CreatePage.php | 7 ++ .../PaymentMethod/CreatePageInterface.php | 7 ++ .../MercanetBnpParibasCheckoutPage.php | 9 +- ...ercanetBnpParibasCheckoutPageInterface.php | 7 ++ .../Mocker/MercanetBnpParibasMocker.php | 7 ++ 28 files changed, 240 insertions(+), 68 deletions(-) diff --git a/composer.json b/composer.json index cf9c59a..ac63b19 100644 --- a/composer.json +++ b/composer.json @@ -19,6 +19,7 @@ "symfony/webpack-encore-bundle": "^1.16" }, "require-dev": { + "doctrine/annotations": "^1.13", "bitbag/coding-standard": "^3.0", "phpstan/extension-installer": "^1.0", "phpstan/phpstan": "^1.8.1", diff --git a/ecs.php b/ecs.php index 0e36d84..abcfbcf 100644 --- a/ecs.php +++ b/ecs.php @@ -1,26 +1,13 @@ paths([ - __DIR__ . '/src', - __DIR__ . '/tests/Behat', - __DIR__ . '/ecs.php', - ]); +return static function (ECSConfig $config): void { - $ecsConfig->import('vendor/sylius-labs/coding-standard/ecs.php'); + putenv('ALLOW_BITBAG_OS_HEADER=1'); - $ecsConfig->skip([ - VisibilityRequiredFixer::class => ['*Spec.php'], - ]); + $config->import('vendor/bitbag/coding-standard/ecs.php'); + $config->paths(['src', 'tests']); }; diff --git a/src/Action/CaptureAction.php b/src/Action/CaptureAction.php index 5463789..d5b6925 100644 --- a/src/Action/CaptureAction.php +++ b/src/Action/CaptureAction.php @@ -1,5 +1,12 @@ mercanetBnpParibasBridge->isPostMethod()) { $model['status'] = $this->mercanetBnpParibasBridge->paymentVerification() ? PaymentInterface::STATE_COMPLETED : PaymentInterface::STATE_CANCELLED @@ -84,7 +91,7 @@ public function execute($request): void return; } - if ($model['status'] === PaymentInterface::STATE_COMPLETED) { + if (PaymentInterface::STATE_COMPLETED === $model['status']) { return; } } diff --git a/src/Action/ConvertPaymentAction.php b/src/Action/ConvertPaymentAction.php index 0191b45..07b8f7a 100644 --- a/src/Action/ConvertPaymentAction.php +++ b/src/Action/ConvertPaymentAction.php @@ -1,5 +1,12 @@ getSource() instanceof PaymentInterface && - $request->getTo() === 'array' + 'array' === $request->getTo() ; } diff --git a/src/Action/NotifyAction.php b/src/Action/NotifyAction.php index c2a17e7..5610d2d 100644 --- a/src/Action/NotifyAction.php +++ b/src/Action/NotifyAction.php @@ -1,5 +1,12 @@ markCanceled(); return; } - if ($status === PaymentInterface::STATE_COMPLETED) { + if (PaymentInterface::STATE_COMPLETED === $status) { $request->markCaptured(); return; diff --git a/src/BitBagMercanetBnpParibasPlugin.php b/src/BitBagMercanetBnpParibasPlugin.php index befa3e2..b7e1e06 100644 --- a/src/BitBagMercanetBnpParibasPlugin.php +++ b/src/BitBagMercanetBnpParibasPlugin.php @@ -1,5 +1,12 @@ $value) { - if ($key != 'keyVersion') { + if ('keyVersion' != $key) { if (is_array($value)) { /** @phpstan-ignore-next-line We should not change our business logic now*/ shaCompose($value); @@ -193,7 +200,7 @@ public function setAmount(int $amount): void if (!is_int($amount)) { throw new \InvalidArgumentException('Integer expected. Amount is always in cents'); } - if ($amount <= 0) { + if (0 >= $amount) { throw new \InvalidArgumentException('Amount must be a positive number'); } $this->parameters['amount'] = $amount; @@ -241,7 +248,7 @@ public function setPaymentBrand(string $brand): void public function setBillingContactEmail(string $email): void { - if (strlen($email) > 50) { + if (50 < strlen($email)) { throw new \InvalidArgumentException('Email is too long'); } if (!filter_var($email, \FILTER_VALIDATE_EMAIL)) { @@ -252,7 +259,7 @@ public function setBillingContactEmail(string $email): void public function setBillingAddressStreet(string $street): void { - if (strlen($street) > 35) { + if (35 < strlen($street)) { throw new \InvalidArgumentException('street is too long'); } $this->parameters['billingAddress.street'] = \Normalizer::normalize($street); @@ -260,7 +267,7 @@ public function setBillingAddressStreet(string $street): void public function setBillingAddressStreetNumber(string $nr): void { - if (strlen($nr) > 10) { + if (10 < strlen($nr)) { throw new \InvalidArgumentException('streetNumber is too long'); } $this->parameters['billingAddress.streetNumber'] = \Normalizer::normalize($nr); @@ -268,7 +275,7 @@ public function setBillingAddressStreetNumber(string $nr): void public function setBillingAddressZipCode(string $zipCode): void { - if (strlen($zipCode) > 10) { + if (10 < strlen($zipCode)) { throw new \InvalidArgumentException('zipCode is too long'); } $this->parameters['billingAddress.zipCode'] = \Normalizer::normalize($zipCode); @@ -276,7 +283,7 @@ public function setBillingAddressZipCode(string $zipCode): void public function setBillingAddressCity(string $city): void { - if (strlen($city) > 25) { + if (25 < strlen($city)) { throw new \InvalidArgumentException('city is too long'); } $this->parameters['billingAddress.city'] = \Normalizer::normalize($city); @@ -284,7 +291,7 @@ public function setBillingAddressCity(string $city): void public function setBillingContactPhone(string $phone): void { - if (strlen($phone) > 30) { + if (30 < strlen($phone)) { throw new \InvalidArgumentException('phone is too long'); } $this->parameters['billingContact.phone'] = $phone; @@ -302,7 +309,7 @@ public function setBillingContactLastname(string $lastname): void public function setCaptureDay(string $number): void { - if (strlen($number) > 2) { + if (2 < strlen($number)) { throw new \InvalidArgumentException('captureDay is too long'); } $this->parameters['captureDay'] = $number; @@ -310,7 +317,7 @@ public function setCaptureDay(string $number): void public function setCaptureMode(string $value): void { - if (strlen($value) > 20) { + if (20 < strlen($value)) { throw new \InvalidArgumentException('captureMode is too long'); } $this->parameters['captureMode'] = $value; @@ -318,7 +325,7 @@ public function setCaptureMode(string $value): void public function setMerchantTransactionDateTime(string $value): void { - if (strlen($value) > 25) { + if (25 < strlen($value)) { throw new \InvalidArgumentException('merchantTransactionDateTime is too long'); } $this->parameters['merchantTransactionDateTime'] = $value; @@ -336,7 +343,7 @@ public function setSealAlgorithm(string $value): void public function setOrderChannel(string $value): void { - if (strlen($value) > 20) { + if (20 < strlen($value)) { throw new \InvalidArgumentException('orderChannel is too long'); } $this->parameters['orderChannel'] = $value; @@ -344,7 +351,7 @@ public function setOrderChannel(string $value): void public function setOrderId(string $value): void { - if (strlen($value) > 32) { + if (32 < strlen($value)) { throw new \InvalidArgumentException('orderId is too long'); } $this->parameters['orderId'] = $value; @@ -352,7 +359,7 @@ public function setOrderId(string $value): void public function setReturnContext(string $value): void { - if (strlen($value) > 255) { + if (255 < strlen($value)) { throw new \InvalidArgumentException('returnContext is too long'); } $this->parameters['returnContext'] = $value; @@ -360,7 +367,7 @@ public function setReturnContext(string $value): void public function setTransactionOrigin(string $value): void { - if (strlen($value) > 20) { + if (20 < strlen($value)) { throw new \InvalidArgumentException('transactionOrigin is too long'); } $this->parameters['transactionOrigin'] = $value; @@ -368,10 +375,10 @@ public function setTransactionOrigin(string $value): void public function setCardNumber(string $number): void { - if (strlen($number) > 19) { + if (19 < strlen($number)) { throw new \InvalidArgumentException('cardNumber is too long'); } - if (strlen($number) < 12) { + if (12 > strlen($number)) { throw new \InvalidArgumentException('cardNumber is too short'); } $this->parameters['cardNumber'] = $number; @@ -379,7 +386,7 @@ public function setCardNumber(string $number): void public function setCardExpiryDate(string $date): void { - if (strlen($date) != 6) { + if (6 != strlen($date)) { throw new \InvalidArgumentException('cardExpiryDate value is invalid'); } $this->parameters['cardExpiryDate'] = $date; @@ -387,7 +394,7 @@ public function setCardExpiryDate(string $date): void public function setCardCSCValue(string $value): void { - if (strlen($value) > 4) { + if (4 < strlen($value)) { throw new \InvalidArgumentException('cardCSCValue value is invalid'); } $this->parameters['cardCSCValue'] = $value; @@ -395,7 +402,7 @@ public function setCardCSCValue(string $value): void public function setFraudDataBypass3DS(string $value): void { - if (strlen($value) > 128) { + if (128 < strlen($value)) { throw new \InvalidArgumentException('fraudData.bypass3DS is too long'); } $this->parameters['fraudData.bypass3DS'] = $value; @@ -403,7 +410,7 @@ public function setFraudDataBypass3DS(string $value): void public function setMerchantWalletId(string $wallet): void { - if (strlen($wallet) > 21) { + if (21 < strlen($wallet)) { throw new \InvalidArgumentException('merchantWalletId is too long'); } $this->parameters['merchantWalletId'] = $wallet; @@ -411,7 +418,7 @@ public function setMerchantWalletId(string $wallet): void public function setPaymentMeanId(string $value): void { - if (strlen($value) > 6) { + if (6 < strlen($value)) { throw new \InvalidArgumentException('paymentMeanId is too long'); } $this->parameters['paymentMeanId'] = $value; @@ -419,10 +426,10 @@ public function setPaymentMeanId(string $value): void public function setInstalmentDataNumber(string $number): void { - if (strlen($number) > 2) { + if (2 < strlen($number)) { throw new \InvalidArgumentException('instalmentData.number is too long'); } - if (($number < 2) || ($number > 50)) { + if ((2 > $number) || (50 < $number)) { throw new \InvalidArgumentException('instalmentData.number invalid value : value must be set between 2 and 50'); } $this->parameters['instalmentData.number'] = $number; @@ -450,7 +457,7 @@ public function setPaymentPattern(string $paymentPattern): void public function __call(string $method, array $args): ?string { - if (substr($method, 0, 3) == 'set') { + if ('set' == substr($method, 0, 3)) { $field = lcfirst(substr($method, 3)); if (in_array($field, $this->pspFields)) { $this->parameters[$field] = $args[0]; @@ -459,7 +466,7 @@ public function __call(string $method, array $args): ?string } } - if (substr($method, 0, 3) == 'get') { + if ('get' == substr($method, 0, 3)) { $field = lcfirst(substr($method, 3)); if (array_key_exists($field, $this->parameters)) { return $this->parameters[$field]; @@ -485,12 +492,12 @@ public function toParameterString(): string $chaine = '{'; foreach ($this->parameters as $key => $val) { $dataArray = explode('.', $key); - if (count($dataArray) > 1) { + if (1 < count($dataArray)) { if ($dataName == $dataArray[0]) { $parameterArray[$dataArray[1]] = $val; } else { - if ($dataName != '') { - if (strlen($chaine) != 1) { + if ('' != $dataName) { + if (1 != strlen($chaine)) { $chaine .= ','; } $chaine .= '"' . $dataName . '":' . json_encode($parameterArray); @@ -501,21 +508,21 @@ public function toParameterString(): string $parameterArray[$dataArray[1]] = $val; } } else { - if ($dataName != '') { - if (strlen($chaine) != 1) { + if ('' != $dataName) { + if (1 != strlen($chaine)) { $chaine .= ','; } $chaine .= '"' . $dataName . '":' . json_encode($parameterArray); $dataName = ''; } - if (strlen($chaine) != 1) { + if (1 != strlen($chaine)) { $chaine .= ','; } $chaine .= '"' . $key . '":"' . $val . '"'; } } - if ($dataName != '') { - if (strlen($chaine) != 1) { + if ('' != $dataName) { + if (1 != strlen($chaine)) { $chaine .= ','; } $chaine .= '"' . $dataName . '":' . json_encode($parameterArray); @@ -555,7 +562,7 @@ protected function validateUri(string $uri): void if (!filter_var($uri, \FILTER_VALIDATE_URL)) { throw new \InvalidArgumentException('Uri is not valid'); } - if (strlen($uri) > 200) { + if (200 < strlen($uri)) { throw new \InvalidArgumentException('Uri is too long'); } } @@ -584,7 +591,7 @@ public function setResponse(array $httpRequest): void private function filterRequestParameters(array $httpRequest): array { - if (!array_key_exists(self::DATA_FIELD, $httpRequest) || $httpRequest[self::DATA_FIELD] == '') { + if (!array_key_exists(self::DATA_FIELD, $httpRequest) || '' == $httpRequest[self::DATA_FIELD]) { throw new \InvalidArgumentException('Data parameter not present in parameters.'); } $parameters = []; @@ -607,7 +614,7 @@ public function getSeal(): string private function extractShaSign(array $parameters): string { - if (!array_key_exists(self::SHASIGN_FIELD, $parameters) || $parameters[self::SHASIGN_FIELD] == '') { + if (!array_key_exists(self::SHASIGN_FIELD, $parameters) || '' == $parameters[self::SHASIGN_FIELD]) { throw new \InvalidArgumentException('SHASIGN parameter not present in parameters.'); } @@ -620,8 +627,8 @@ public function isValid(): bool $signature = $this->responseData; $compute = hash('sha256', utf8_encode($signature . $this->secretKey)); - if (strcmp($this->shaSign, $compute) == 0) { - if ((strcmp($this->parameters['responseCode'], '00') == 0) || (strcmp($this->parameters['responseCode'], '60') == 0)) { + if (0 == strcmp($this->shaSign, $compute)) { + if ((0 == strcmp($this->parameters['responseCode'], '00')) || (0 == strcmp($this->parameters['responseCode'], '60'))) { $resultat = true; } } @@ -674,7 +681,7 @@ public function executeRequest(): ?string die(); } - if ($info['http_code'] != 200) { + if (200 != $info['http_code']) { echo 'service error: ' . $info['http_code'] . "\n"; echo 'return: ' . $result . "\n"; curl_close($ch); @@ -682,13 +689,13 @@ public function executeRequest(): ?string } curl_close($ch); - if (strlen($result) == 0) { + if (0 == strlen($result)) { echo "service did not sent back data\n"; die(); } $result_array = json_decode($result); - if ($result_array->redirectionStatusCode == '00') { + if ('00' == $result_array->redirectionStatusCode) { return '
' . '' . '' . diff --git a/src/Legacy/SimplePayment.php b/src/Legacy/SimplePayment.php index 1cde608..593872e 100755 --- a/src/Legacy/SimplePayment.php +++ b/src/Legacy/SimplePayment.php @@ -1,5 +1,12 @@ =1.2) diff --git a/tests/Application/config/bundles.php b/tests/Application/config/bundles.php index d0dcd50..1a2a0f2 100644 --- a/tests/Application/config/bundles.php +++ b/tests/Application/config/bundles.php @@ -1,5 +1,14 @@ ['all' => true], Symfony\Bundle\MonologBundle\MonologBundle::class => ['all' => true], diff --git a/tests/Application/config/sylius/1.13/bundles.php b/tests/Application/config/sylius/1.13/bundles.php index 5d54121..e615f85 100644 --- a/tests/Application/config/sylius/1.13/bundles.php +++ b/tests/Application/config/sylius/1.13/bundles.php @@ -1,5 +1,12 @@