From 5bb317a8c2c43ce8e36e465132c144fcf797dcda Mon Sep 17 00:00:00 2001 From: Vitalij Mik Date: Mon, 9 Sep 2024 10:59:04 +0200 Subject: [PATCH] NTR: PISHPW-230: Add payconiq payment (#424) Co-authored-by: Vitalij Mik --- Components/Constants/PaymentMethod.php | 1 + .../PaymentMethodsInstaller.php | 3 +- Services/Mollie/Payments/PaymentFactory.php | 4 + .../Mollie/Payments/Requests/Payconiq.php | 25 ++++ .../Installer/PaymentMethodsInstallerTest.php | 1 + .../Mollie/Payments/Requests/PayconiqTest.php | 138 ++++++++++++++++++ 6 files changed, 171 insertions(+), 1 deletion(-) create mode 100644 Services/Mollie/Payments/Requests/Payconiq.php create mode 100644 Tests/PHPUnit/Services/Mollie/Payments/Requests/PayconiqTest.php diff --git a/Components/Constants/PaymentMethod.php b/Components/Constants/PaymentMethod.php index b12f4345..735eb4b7 100644 --- a/Components/Constants/PaymentMethod.php +++ b/Components/Constants/PaymentMethod.php @@ -34,4 +34,5 @@ class PaymentMethod const BANCOMAT_PAY = "bancomatpay"; const BLIK = "blik"; const RIVERTY = "riverty"; + const PAYCONIQ = "payconiq"; } diff --git a/Components/Installer/PaymentMethods/PaymentMethodsInstaller.php b/Components/Installer/PaymentMethods/PaymentMethodsInstaller.php index 553bf37e..62ba2578 100644 --- a/Components/Installer/PaymentMethods/PaymentMethodsInstaller.php +++ b/Components/Installer/PaymentMethods/PaymentMethodsInstaller.php @@ -123,7 +123,8 @@ public static function getSupportedPaymentMethods() PaymentMethod::BANCOMAT_PAY, PaymentMethod::BLIK, PaymentMethod::KLARNA_ONE, - PaymentMethod::RIVERTY + PaymentMethod::RIVERTY, + PaymentMethod::PAYCONIQ, ]; } diff --git a/Services/Mollie/Payments/PaymentFactory.php b/Services/Mollie/Payments/PaymentFactory.php index 01f290b9..db0d50e4 100644 --- a/Services/Mollie/Payments/PaymentFactory.php +++ b/Services/Mollie/Payments/PaymentFactory.php @@ -19,6 +19,7 @@ use MollieShopware\Services\Mollie\Payments\Requests\In3; use MollieShopware\Services\Mollie\Payments\Requests\KBC; use MollieShopware\Services\Mollie\Payments\Requests\Klarna; +use MollieShopware\Services\Mollie\Payments\Requests\Payconiq; use MollieShopware\Services\Mollie\Payments\Requests\PayLater; use MollieShopware\Services\Mollie\Payments\Requests\PayNow; use MollieShopware\Services\Mollie\Payments\Requests\PayPal; @@ -119,6 +120,9 @@ public function createByPaymentName($paymentMethod) case PaymentMethod::RIVERTY: return new Riverty(); + + case PaymentMethod::PAYCONIQ: + return new PayConiq(); } throw new \Exception('Payment handler not found for: ' . $paymentMethod); diff --git a/Services/Mollie/Payments/Requests/Payconiq.php b/Services/Mollie/Payments/Requests/Payconiq.php new file mode 100644 index 00000000..c02feaf1 --- /dev/null +++ b/Services/Mollie/Payments/Requests/Payconiq.php @@ -0,0 +1,25 @@ +assertEquals($expected, PaymentMethodsInstaller::getSupportedPaymentMethods()); diff --git a/Tests/PHPUnit/Services/Mollie/Payments/Requests/PayconiqTest.php b/Tests/PHPUnit/Services/Mollie/Payments/Requests/PayconiqTest.php new file mode 100644 index 00000000..c4270e93 --- /dev/null +++ b/Tests/PHPUnit/Services/Mollie/Payments/Requests/PayconiqTest.php @@ -0,0 +1,138 @@ +payment = new Payconiq(); + + $this->addressInvoice = $this->getAddressFixture1(); + $this->addressShipping = $this->getAddressFixture2(); + $this->lineItem = $this->getLineItemFixture(); + + $this->payment->setPayment( + new Payment( + 'UUID-123', + 'Payment UUID-123', + '20004', + $this->addressInvoice, + $this->addressShipping, + 49.98, + [$this->lineItem], + 'CHF', + 'de_DE', + 'https://local/redirect', + 'https://local/notify' + ) + ); + } + + /** + * This test verifies that the Payments-API request + * for our payment is correct. + * Please note, Twint does not work with the payments API + * so this is just an empty array + */ + public function testPaymentsAPI() + { + $expected = [ + 'method' => PaymentMethod::PAYCONIQ, + 'amount' => [ + 'currency' => 'CHF', + 'value' => '49.98', + ], + 'description' => 'Payment UUID-123', + 'redirectUrl' => 'https://local/redirect', + 'webhookUrl' => 'https://local/notify', + 'locale' => 'de_DE', + ]; + + $requestBody = $this->payment->buildBodyPaymentsAPI(); + + $this->assertEquals($expected, $requestBody); + } + + /** + * This test verifies that the Orders-API request + * for our payment is correct. + */ + public function testOrdersAPI() + { + $expected = [ + 'method' => PaymentMethod::PAYCONIQ, + 'amount' => [ + 'currency' => 'CHF', + 'value' => '49.98', + ], + 'redirectUrl' => 'https://local/redirect', + 'webhookUrl' => 'https://local/notify', + 'locale' => 'de_DE', + 'orderNumber' => '20004', + 'payment' => [ + 'webhookUrl' => 'https://local/notify', + ], + 'billingAddress' => $this->getExpectedAddressStructure($this->addressInvoice), + 'shippingAddress' => $this->getExpectedAddressStructure($this->addressShipping), + 'lines' => [ + $this->getExpectedLineItemStructure($this->lineItem), + ], + 'metadata' => [], + ]; + + $requestBody = $this->payment->buildBodyOrdersAPI(); + + $this->assertSame($expected, $requestBody); + } + + /** + * This test verifies that we can set a custom expiration date + * for our Orders API request. + */ + public function testExpirationDate() + { + $dueInDays = 5; + $expectedDueDate = date('Y-m-d', strtotime(' + ' . $dueInDays . ' day')); + + $this->payment->setExpirationDays($dueInDays); + $request = $this->payment->buildBodyOrdersAPI(); + + $this->assertEquals($expectedDueDate, $request['expiresAt']); + } +}