From f276a396539d3bb9cf9b8f5fbffb4ff460646c12 Mon Sep 17 00:00:00 2001 From: Manuel Reinhard Date: Mon, 20 Apr 2020 21:27:27 +0200 Subject: [PATCH 1/2] Allow customer ids between 4 and 11 chars in QrPaymentReferenceGenerator --- src/Reference/QrPaymentReferenceGenerator.php | 23 +++++++++---- .../QrPaymentReferenceGeneratorTest.php | 32 ++++++++++++++++--- 2 files changed, 44 insertions(+), 11 deletions(-) diff --git a/src/Reference/QrPaymentReferenceGenerator.php b/src/Reference/QrPaymentReferenceGenerator.php index b875d75c..120352c1 100644 --- a/src/Reference/QrPaymentReferenceGenerator.php +++ b/src/Reference/QrPaymentReferenceGenerator.php @@ -6,6 +6,7 @@ use Sprain\SwissQrBill\Validator\SelfValidatableInterface; use Sprain\SwissQrBill\Validator\SelfValidatableTrait; use Symfony\Component\Validator\Constraints as Assert; +use Symfony\Component\Validator\Context\ExecutionContextInterface; use Symfony\Component\Validator\Mapping\ClassMetadata; class QrPaymentReferenceGenerator implements SelfValidatableInterface @@ -37,7 +38,7 @@ public function getReferenceNumber(): ?string return $this->referenceNumber; } - public function doGenerate() + private function doGenerate() { if (!$this->isValid()) { throw new InvalidQrPaymentReferenceException( @@ -45,8 +46,8 @@ public function doGenerate() ); } - $completeReferenceNumber = str_pad($this->getCustomerIdentificationNumber(), 6, '0', STR_PAD_RIGHT); - $completeReferenceNumber .= str_pad($this->getReferenceNumber(), 20, '0', STR_PAD_LEFT); + $completeReferenceNumber = $this->getCustomerIdentificationNumber(); + $completeReferenceNumber .= str_pad($this->getReferenceNumber(), 26 - strlen($completeReferenceNumber), '0', STR_PAD_LEFT); $completeReferenceNumber .= $this->modulo10($completeReferenceNumber); return $completeReferenceNumber; @@ -61,7 +62,8 @@ public static function loadValidatorMetadata(ClassMetadata $metadata): void 'match' => true ]), new Assert\Length([ - 'max' => 6 + 'max' => 11, + 'min' => 4 ]), new Assert\NotBlank() ]); @@ -72,11 +74,18 @@ public static function loadValidatorMetadata(ClassMetadata $metadata): void 'pattern' => '/^\d*$/', 'match' => true ]), - new Assert\Length([ - 'max' => 20 - ]), new Assert\NotBlank() ]); + + $metadata->addConstraint(new Assert\Callback('validateFullReference')); + } + + public function validateFullReference(ExecutionContextInterface $context, $payload) + { + if (strlen($this->customerIdentificationNumber) + strlen($this->referenceNumber) > 26) { + $context->buildViolation('The length of customer identification number + reference number may not exceed 26 characters in total.') + ->addViolation(); + } } private function removeWhitespace(string $string): string diff --git a/tests/Reference/QrPaymentReferenceGeneratorTest.php b/tests/Reference/QrPaymentReferenceGeneratorTest.php index 1cb76eeb..b1addeeb 100644 --- a/tests/Reference/QrPaymentReferenceGeneratorTest.php +++ b/tests/Reference/QrPaymentReferenceGeneratorTest.php @@ -40,6 +40,9 @@ public function qrPaymentReferenceProvider() ['040329', '340 ', '040329000000000000000003406'], // https://www.lukb.ch/documents/10620/13334/LUKB-BESR-Handbuch.pdf ['247656', '3073000002311006 ', '247656000030730000023110061'], // https://hilfe.flexbuero.ch/article/1181/ ['123456', '11223344', '123456000000000000112233440'], + ['1234567890', '11223344', '123456789000000000112233444'], + ['1234', '11223344', '123400000000000000112233449'], + ['000000', '11223344', '000000000000000000112233442'], // Handle it as numerics as well [310014, 18310019779911119, '310014000183100197799111196'], @@ -49,13 +52,34 @@ public function qrPaymentReferenceProvider() ]; } + /** + * @dataProvider invalidQrPaymentReferenceProvider + * @expectedException Sprain\SwissQrBill\Validator\Exception\InvalidQrPaymentReferenceException + */ + public function testInvalidQrPaymentReference($customerIdentification, $referenceNumber) + { + QrPaymentReferenceGenerator::generate( + $customerIdentification, + $referenceNumber + ); + } + + public function invalidQrPaymentReferenceProvider() + { + return [ + ['1234', '12345678901234567890123'], // too long in total + ['123456', '123456789012345678901'], // too long in total + ['12345678901', '1234567890123456'], // too long in total + ]; + } + /** * @dataProvider invalidCustomerIdentificationNumberProvider * @expectedException Sprain\SwissQrBill\Validator\Exception\InvalidQrPaymentReferenceException */ public function testInvalidCustomerIdentificationNumber($value) { - $qrReference = QrPaymentReferenceGenerator::generate( + QrPaymentReferenceGenerator::generate( $value, '18310019779911119' ); @@ -64,7 +88,8 @@ public function testInvalidCustomerIdentificationNumber($value) public function invalidCustomerIdentificationNumberProvider() { return [ - ['1234567'], // too long + ['123'], // too short + ['123456789012'], // too long ['12345A'], // non-digits ['1234.5'], // non-digits [''] @@ -77,7 +102,7 @@ public function invalidCustomerIdentificationNumberProvider() */ public function testInvalidReferenceNumber($value) { - $qrReference = QrPaymentReferenceGenerator::generate( + QrPaymentReferenceGenerator::generate( '123456', $value ); @@ -86,7 +111,6 @@ public function testInvalidReferenceNumber($value) public function invalidReferenceNumberProvider() { return [ - ['123456789012345678901'], // too long ['1234567890123456789A'], // non-digits ['123456789012345678.0'], // non-digits [''] From 91afeba98c7cb3f83c76d6d532b9c2f388eb23fc Mon Sep 17 00:00:00 2001 From: Manuel Reinhard Date: Mon, 20 Apr 2020 21:47:35 +0200 Subject: [PATCH 2/2] Allow customer ids between 0 and 11 chars in QrPaymentReferenceGenerator, including NULL --- src/Reference/QrPaymentReferenceGenerator.php | 11 ++++++----- tests/Reference/QrPaymentReferenceGeneratorTest.php | 5 +++-- 2 files changed, 9 insertions(+), 7 deletions(-) diff --git a/src/Reference/QrPaymentReferenceGenerator.php b/src/Reference/QrPaymentReferenceGenerator.php index 120352c1..8a174c69 100644 --- a/src/Reference/QrPaymentReferenceGenerator.php +++ b/src/Reference/QrPaymentReferenceGenerator.php @@ -19,10 +19,13 @@ class QrPaymentReferenceGenerator implements SelfValidatableInterface /** @var string */ private $referenceNumber; - public static function generate(string $customerIdentificationNumber, string $referenceNumber) + public static function generate(?string $customerIdentificationNumber, string $referenceNumber) { $qrPaymentReferenceGenerator = new self(); - $qrPaymentReferenceGenerator->customerIdentificationNumber = $qrPaymentReferenceGenerator->removeWhitespace($customerIdentificationNumber); + + if (null !== $customerIdentificationNumber) { + $qrPaymentReferenceGenerator->customerIdentificationNumber = $qrPaymentReferenceGenerator->removeWhitespace($customerIdentificationNumber); + } $qrPaymentReferenceGenerator->referenceNumber = $qrPaymentReferenceGenerator->removeWhitespace($referenceNumber); return $qrPaymentReferenceGenerator->doGenerate(); @@ -62,10 +65,8 @@ public static function loadValidatorMetadata(ClassMetadata $metadata): void 'match' => true ]), new Assert\Length([ - 'max' => 11, - 'min' => 4 + 'max' => 11 ]), - new Assert\NotBlank() ]); $metadata->addPropertyConstraints('referenceNumber', [ diff --git a/tests/Reference/QrPaymentReferenceGeneratorTest.php b/tests/Reference/QrPaymentReferenceGeneratorTest.php index b1addeeb..178b93cd 100644 --- a/tests/Reference/QrPaymentReferenceGeneratorTest.php +++ b/tests/Reference/QrPaymentReferenceGeneratorTest.php @@ -43,6 +43,8 @@ public function qrPaymentReferenceProvider() ['1234567890', '11223344', '123456789000000000112233444'], ['1234', '11223344', '123400000000000000112233449'], ['000000', '11223344', '000000000000000000112233442'], + ['', '11223344', '000000000000000000112233442'], + [null, '11223344', '000000000000000000112233442'], // Handle it as numerics as well [310014, 18310019779911119, '310014000183100197799111196'], @@ -70,6 +72,7 @@ public function invalidQrPaymentReferenceProvider() ['1234', '12345678901234567890123'], // too long in total ['123456', '123456789012345678901'], // too long in total ['12345678901', '1234567890123456'], // too long in total + [null, '123456789012345678901234567'], // too long in total ]; } @@ -88,11 +91,9 @@ public function testInvalidCustomerIdentificationNumber($value) public function invalidCustomerIdentificationNumberProvider() { return [ - ['123'], // too short ['123456789012'], // too long ['12345A'], // non-digits ['1234.5'], // non-digits - [''] ]; }