app/django/utils/checksums.py
author Sverre Rabbelier <srabbelier@gmail.com>
Sat, 28 Mar 2009 20:19:50 +0000
changeset 2026 388b65cabfbb
parent 54 03e267d67478
permissions -rw-r--r--
Set fields to 100% width again This patch properly fixes the problem without punishing other browsers for IE's brokenness. If we have any other IE specific fixes, we should include them in this way too. Patch by: Timothy Robert Ansell <tansell@google.com>

"""
Common checksum routines (used in multiple localflavor/ cases, for example).
"""

__all__ = ['luhn',]

LUHN_ODD_LOOKUP = (0, 2, 4, 6, 8, 1, 3, 5, 7, 9) # sum_of_digits(index * 2)

def luhn(candidate):
    """
    Checks a candidate number for validity according to the Luhn
    algorithm (used in validation of, for example, credit cards).
    Both numeric and string candidates are accepted.
    """
    if not isinstance(candidate, basestring):
        candidate = str(candidate)
    try:
        evens = sum([int(c) for c in candidate[-1::-2]])
        odds = sum([LUHN_ODD_LOOKUP[int(c)] for c in candidate[-2::-2]])
        return ((evens + odds) % 10 == 0)
    except ValueError:  # Raised if an int conversion fails
        return False