lists.arthurdejong.org
RSS feed

python-stdnum branch master updated. 2.1-16-gd534b3c

[Date Prev][Date Next] [Thread Prev][Thread Next]

python-stdnum branch master updated. 2.1-16-gd534b3c



This is an automated email from the git hooks/post-receive script. It was
generated because a ref change was pushed to the repository containing
the project "python-stdnum".

The branch, master has been updated
       via  d534b3c6b8baae7e84a9b79bd06dc21070826af1 (commit)
      from  2cf475c07acbb34ea062a9e87d685175e485c61d (commit)

Those revisions listed above that are new to this repository have
not appeared on any other notification email; so we list those
revisions in full, below.

- Log -----------------------------------------------------------------
https://arthurdejong.org/git/python-stdnum/commit/?id=d534b3c6b8baae7e84a9b79bd06dc21070826af1

commit d534b3c6b8baae7e84a9b79bd06dc21070826af1
Author: Cédric Krier <ced@b2ck.com>
Date:   Sun Sep 28 12:38:47 2025 +0200

    Add Belgian OGM-VCS
    
    Closes https://github.com/arthurdejong/python-stdnum/pull/487

diff --git a/stdnum/be/ogm_vcs.py b/stdnum/be/ogm_vcs.py
new file mode 100644
index 0000000..8e3f857
--- /dev/null
+++ b/stdnum/be/ogm_vcs.py
@@ -0,0 +1,81 @@
+# ogm_vcs.py - functions for handling Belgian OGM-VCS
+# coding: utf-8
+#
+# Copyright (C) 2025 Cédric Krier
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+# 02110-1301 USA
+
+"""Belgian OGM-VCS.
+
+The OGM-VCS is used in bank transfer as structured communication.
+
+* 
https://febelfin.be/en/publications/2023/febelfin-banking-standards-for-online-banking
+
+>>> validate('+++010/8068/17183+++')
+'010806817183'
+>>> validate('010/8068/17180')
+Traceback (most recent call last):
+    ...
+InvalidChecksum: ...
+>>> format('010806817183')
+'010/8068/17183'
+>>> calc_check_digits('0108068171')
+'83'
+"""
+
+from __future__ import annotations
+
+from stdnum.exceptions import *
+from stdnum.util import clean, isdigits
+
+
+def compact(number: str) -> str:
+    """Convert the number to the minimal representation. This strips the number
+    of any invalid separators and removes surrounding whitespace."""
+    return clean(number, ' +/').strip()
+
+
+def calc_check_digits(number: str) -> str:
+    """Calculate the check digit that should be added."""
+    number = compact(number)
+    return '%02d' % ((int(number[:10]) % 97) or 97)
+
+
+def validate(number: str) -> str:
+    """Check if the number is a valid OGM-VCS."""
+    number = compact(number)
+    if not isdigits(number) or int(number) <= 0:
+        raise InvalidFormat()
+    if len(number) != 12:
+        raise InvalidLength()
+    if calc_check_digits(number) != number[-2:]:
+        raise InvalidChecksum()
+    return number
+
+
+def is_valid(number: str) -> bool:
+    """Check if the number is a valid VAT number."""
+    try:
+        return bool(validate(number))
+    except ValidationError:
+        return False
+
+
+def format(number: str) -> str:
+    """Format the number provided for output."""
+    number = compact(number)
+    number = number.rjust(12, '0')
+    return f'{number[:3]}/{number[3:7]}/{number[7:]}'

-----------------------------------------------------------------------

Summary of changes:
 stdnum/{lu/tva.py => be/ogm_vcs.py} | 52 +++++++++++++++++++++----------------
 1 file changed, 30 insertions(+), 22 deletions(-)
 copy stdnum/{lu/tva.py => be/ogm_vcs.py} (57%)


hooks/post-receive
-- 
python-stdnum