From e5b758c0a9a53aef8cb76dbec4d14727de095952 Mon Sep 17 00:00:00 2001 From: Vincent Langlet Date: Wed, 22 Nov 2023 13:30:40 +0100 Subject: [PATCH 1/2] Allow to chose behavior if country is not supported --- src/Validator.php | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/src/Validator.php b/src/Validator.php index fc3e199..bac22e5 100644 --- a/src/Validator.php +++ b/src/Validator.php @@ -87,14 +87,22 @@ public function validateIpAddress(string $ipAddress): bool return (bool) filter_var($ipAddress, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE); } + public function hasSupportedCountryPrefix(string $vatNumber): bool + { + $country = substr($vatNumber, 0, 2); + + return isset($this->patterns[$country]); + } + /** * Validate a VAT number format. This does not check whether the VAT number was really issued. * * @param string $vatNumber + * @param bool $skipIfUnsupported * * @return boolean */ - public function validateVatNumberFormat(string $vatNumber): bool + public function validateVatNumberFormat(string $vatNumber, bool $skipIfUnsupported = false): bool { if ($vatNumber === '') { return false; @@ -105,7 +113,7 @@ public function validateVatNumberFormat(string $vatNumber): bool $number = substr($vatNumber, 2); if (! isset($this->patterns[$country])) { - return false; + return $skipIfUnsupported; } return preg_match('/^' . $this->patterns[$country] . '$/', $number) > 0; From e4409423fdbfe53ec6b818c1de4d5c088ce14552 Mon Sep 17 00:00:00 2001 From: Vincent Langlet Date: Mon, 29 Jan 2024 14:55:40 +0100 Subject: [PATCH 2/2] Throw exception --- src/Validator.php | 5 ++--- tests/ValidatorTest.php | 8 -------- 2 files changed, 2 insertions(+), 11 deletions(-) diff --git a/src/Validator.php b/src/Validator.php index bac22e5..12e7770 100644 --- a/src/Validator.php +++ b/src/Validator.php @@ -98,11 +98,10 @@ public function hasSupportedCountryPrefix(string $vatNumber): bool * Validate a VAT number format. This does not check whether the VAT number was really issued. * * @param string $vatNumber - * @param bool $skipIfUnsupported * * @return boolean */ - public function validateVatNumberFormat(string $vatNumber, bool $skipIfUnsupported = false): bool + public function validateVatNumberFormat(string $vatNumber): bool { if ($vatNumber === '') { return false; @@ -113,7 +112,7 @@ public function validateVatNumberFormat(string $vatNumber, bool $skipIfUnsupport $number = substr($vatNumber, 2); if (! isset($this->patterns[$country])) { - return $skipIfUnsupported; + throw new \InvalidArgumentException('The vat country prefix is not supported.'); } return preg_match('/^' . $this->patterns[$country] . '$/', $number) > 0; diff --git a/tests/ValidatorTest.php b/tests/ValidatorTest.php index 847bc49..b4fb3f3 100644 --- a/tests/ValidatorTest.php +++ b/tests/ValidatorTest.php @@ -96,14 +96,6 @@ public function testValidateVatNumberFormat() 'SI1234567', 'SK123456789', - // valid number but with prefix - 'invalid_prefix_GB999999973', - 'invalid_prefix_IE1234567X', - 'invalid_prefix_ESB1234567C', - 'invalid_prefix_BE0123456789', - 'invalid_prefix_MT12345678', - 'invalid_prefix_LT123456789', - // valid number but with suffix 'IE1234567X_invalid_suffix', 'ESB1234567C_invalid_suffix',