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
- From: Commits of the python-stdnum project <python-stdnum-commits [at] lists.arthurdejong.org>
- To: python-stdnum-commits [at] lists.arthurdejong.org
- Reply-to: python-stdnum-users [at] lists.arthurdejong.org
- Subject: python-stdnum commit: r63 - in python-stdnum: . stdnum stdnum/us tests
- Date: Sun, 6 Feb 2011 15:00:10 +0100 (CET)
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
- python-stdnum commit: r63 - in python-stdnum: . stdnum stdnum/us tests,
Commits of the python-stdnum project