lists.arthurdejong.org
RSS feed

python-stdnum commit: r63 - in python-stdnum: . stdnum stdnum/us tests

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

python-stdnum commit: r63 - in python-stdnum: . stdnum stdnum/us tests



Author: arthur
Date: Sun Feb  6 15:00:07 2011
New Revision: 63
URL: http://arthurdejong.org/viewvc/python-stdnum?view=rev&revision=63

Log:
add an SSN (U.S. Social Security Number) module

Added:
   python-stdnum/stdnum/us/
   python-stdnum/stdnum/us/__init__.py
   python-stdnum/stdnum/us/ssn.py
Modified:
   python-stdnum/README
   python-stdnum/stdnum/__init__.py
   python-stdnum/tests/test_robustness.doctest

Modified: python-stdnum/README
==============================================================================
--- python-stdnum/README        Sat Feb  5 23:48:39 2011        (r62)
+++ python-stdnum/README        Sun Feb  6 15:00:07 2011        (r63)
@@ -16,6 +16,7 @@
  * BSN (Burgerservicenummer, the Dutch national identification number)
  * CPF (Cadastro de Pessoas Físicas, the Brazillian national identification
    number)
+ * SSN (U.S. Social Security Number)
  * IMEI (International Mobile Equipment Identity)
  * MEID (Mobile Equipment Identifier)
  * GRid (Global Release Identifier)

Modified: python-stdnum/stdnum/__init__.py
==============================================================================
--- python-stdnum/stdnum/__init__.py    Sat Feb  5 23:48:39 2011        (r62)
+++ python-stdnum/stdnum/__init__.py    Sun Feb  6 15:00:07 2011        (r63)
@@ -30,6 +30,7 @@
  * BSN (Burgerservicenummer, the Dutch national identification number)
  * CPF (Cadastro de Pessoas Físicas, the Brazillian national identification
    number)
+ * SSN (U.S. Social Security Number)
  * IMEI (International Mobile Equipment Identity)
  * MEID (Mobile Equipment Identifier)
  * GRid (Global Release Identifier)

Added: python-stdnum/stdnum/us/__init__.py
==============================================================================

Added: python-stdnum/stdnum/us/ssn.py
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ python-stdnum/stdnum/us/ssn.py      Sun Feb  6 15:00:07 2011        (r63)
@@ -0,0 +1,72 @@
+# ssn.py - functions for handling SSNs
+#
+# Copyright (C) 2011 Arthur de Jong
+#
+# 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
+
+"""Module for handling U.S. Social Security Numbers (SSN), the number
+to identify individuals for taxation purposes.
+
+>>> is_valid('111-22-3333')
+True
+>>> is_valid('1112-23333')
+False
+>>> is_valid('666-00-0000')
+False
+>>> compact('1234-56-789')
+'123456789'
+>>> format('111223333')
+'111-22-3333'
+"""
+
+import re
+
+# regular expression for matching SSN
+_ssn_re = 
re.compile('^(?P<area>[0-9]{3})-?(?P<group>[0-9]{2})-?(?P<serial>[0-9]{4})$')
+
+# blacklist of SSNs
+_ssn_blacklist = set(( '078-05-1120', '457-55-5462', '219-09-9999' ))
+
+def compact(number):
+    """Convert the number to the minimal representation. This strips the
+    number of any valid separators and removes surrounding whitespace."""
+    return number.replace('-', '').strip()
+
+def is_valid(number):
+    """Checks to see if the number provided is a valid SSN. This checks
+    the length, groups and formatting if it is present."""
+    try:
+        match = _ssn_re.search(number.strip())
+    except:
+        return False
+    if not match:
+        return False
+    area = match.group('area')
+    group = match.group('group')
+    serial = match.group('serial')
+    # check for all-0 or some unused areas
+    # (9xx also won't be issued which includes the advertising range)
+    if area == '000' or area == '666' or area[0] == '9' or \
+       group == '00' or serial == '0000':
+        return False
+    # check blacklists
+    return format(number) not in _ssn_blacklist
+
+def format(number):
+    """Reformat the passed number to the standard format."""
+    if len(number) == 9:
+        number = number[:3] + '-' + number[3:5] + '-' + number[5:]
+    return number

Modified: python-stdnum/tests/test_robustness.doctest
==============================================================================
--- python-stdnum/tests/test_robustness.doctest Sat Feb  5 23:48:39 2011        
(r62)
+++ python-stdnum/tests/test_robustness.doctest Sun Feb  6 15:00:07 2011        
(r63)
@@ -29,6 +29,7 @@
 >>> from stdnum.iso7064 import mod_11_10, mod_11_2, mod_37_2, mod_37_36, 
 >>> mod_97_10
 >>> from stdnum.nl import bsn
 >>> from stdnum.br import cpf
+>>> from stdnum.us import ssn
 
 Go over each imported module and try every value.
 
-- 
To unsubscribe send an email to
python-stdnum-commits-unsubscribe@lists.arthurdejong.org or see
http://lists.arthurdejong.org/python-stdnum-commits