- def check_vat_dk(self, vat):
- '''
- Check Denmark VAT number.
- '''
- if len(vat) != 8:
- return False
- try:
- int(vat)
- except:
- return False
- if int(vat[0]) <= 0:
- return False
- sum = 2 * int(vat[0]) + 7 * int(vat[1]) + 6 * int(vat[2]) + \
- 5 * int(vat[3]) + 4 * int(vat[4]) + 3 * int(vat[5]) + \
- 2 * int(vat[6]) + int(vat[7])
- if sum % 11 != 0:
- return False
- return True
-
- def check_vat_ee(self, vat):
- '''
- Check Estonia VAT number.
- '''
- if len(vat) != 9:
- return False
- try:
- int(vat)
- except:
- return False
- sum = 3 * int(vat[0]) + 7 * int(vat[1]) + 1 * int(vat[2]) + \
- 3 * int(vat[3]) + 7 * int(vat[4]) + 1 * int(vat[5]) + \
- 3 * int(vat[6]) + 7 * int(vat[7])
- check = 10 - (sum % 10)
- if check == 10:
- check = 0
- if check != int(vat[8]):
- return False
- return True
-
- def check_vat_es(self, vat):
- '''
- Check Spain VAT number.
- '''
- if len(vat) != 9:
- return False
-
- conv = {
- 1: 'T',
- 2: 'R',
- 3: 'W',
- 4: 'A',
- 5: 'G',
- 6: 'M',
- 7: 'Y',
- 8: 'F',
- 9: 'P',
- 10: 'D',
- 11: 'X',
- 12: 'B',
- 13: 'N',
- 14: 'J',
- 15: 'Z',
- 16: 'S',
- 17: 'Q',
- 18: 'V',
- 19: 'H',
- 20: 'L',
- 21: 'C',
- 22: 'K',
- 23: 'E',
- }
- #Legal persons with profit aim
- if vat[0] in ('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'J', 'U', 'V'):
- try:
- int(vat[1:8])
- except:
- return False
- sum = mult_add(2, int(vat[1])) + int(vat[2]) + \
- mult_add(2, int(vat[3])) + int(vat[4]) + \
- mult_add(2, int(vat[5])) + int(vat[6]) + \
- mult_add(2, int(vat[7]))
- check = 10 - (sum % 10)
- if check == 10:
- check = 0
- return True
- #Legal persons with non-profit aim
- elif vat[0] in ('N', 'P', 'Q', 'R', 'S', 'W'):
- try:
- int(vat[1:8])
- except:
- return False
- sum = mult_add(2, int(vat[1])) + int(vat[2]) + \
- mult_add(2, int(vat[3])) + int(vat[4]) + \
- mult_add(2, int(vat[5])) + int(vat[6]) + \
- mult_add(2, int(vat[7]))
- check = 10 - (sum % 10)
- check = chr(check + 64)
- if check != vat[8]:
- return False
- return True
- #Foreign natural persons, under age 14 or non-residents
- elif vat[0] in ('K', 'L', 'M', 'X', 'Y', 'Z'):
- if vat[0] == 'Y':
- check_value = '1' + vat[1:8]
- elif vat[0] == 'Z':
- check_value = '2' + vat[1:8]
- else:
- check_value = vat[1:8]
-
- try:
- int(check_value)
- except:
- return False
- check = 1 + (int(check_value) % 23)
-
- check = conv[check]
- if check != vat[8]:
- return False
- return True
- #Spanish natural persons
- else:
- try:
- int(vat[:8])
- except:
- return False
- check = 1 + (int(vat[:8]) % 23)
-
- check = conv[check]
- if check != vat[8]:
- return False
- return True
-
- def check_vat_fi(self, vat):
- '''
- Check Finland VAT number.
- '''
- if len(vat) != 8:
- return False
- try:
- int(vat)
- except:
- return False
- sum = 7 * int(vat[0]) + 9 * int(vat[1]) + 10 * int(vat[2]) + \
- 5 * int(vat[3]) + 8 * int(vat[4]) + 4 * int(vat[5]) + \
- 2 * int(vat[6])
- check = 11 - (sum % 11)
- if check == 11:
- check = 0
- if check == 10:
- return False
- if check != int(vat[7]):
- return False
- return True
-
- def check_vat_fr(self, vat):
- '''
- Check France VAT number.
- '''
- if len(vat) != 11:
- return False
-
- try:
- int(vat[2:11])
- except:
- return False
-
- system = None
- try:
- int(vat[0:2])
- system = 'old'
- except:
- system = 'new'
-
- if system == 'old':
- check = ((int(vat[2:11]) * 100) + 12) % 97
- if check != int(vat[0:2]):
- return False
- return True
- else:
- conv = ['0', '1', '2', '3', '4', '5', '6', '7',
- '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H',
- 'J', 'K', 'L', 'M', 'N', 'P', 'Q', 'R', 'S', 'T',
- 'U', 'V', 'W', 'X', 'Y', 'Z']
- if vat[0] not in conv \
- or vat[1] not in conv:
- return False
- c1 = conv.index(vat[0])
- c2 = conv.index(vat[1])
-
- if c1 < 10:
- sum = c1 * 24 + c2 - 10
- else:
- sum = c1 * 34 + c2 - 100
-
- x = sum % 11
- sum = (int(sum) / 11) + 1
- y = (int(vat[2:11]) + sum) % 11
- if x != y:
- return False
- return True
-
- def check_vat_gb(self, vat):
- '''
- Check United Kingdom VAT number.
- '''
-
- if len(vat) == 5:
- try:
- int(vat[2:5])
- except:
- return False
-
- if vat[0:2] == 'GD':
- if int(vat[2:5]) >= 500:
- return False
- return True
- if vat[0:2] == 'HA':
- if int(vat[2:5]) < 500:
- return False
- return True
- return False
- elif len(vat) in (9, 10):
- try:
- int(vat)
- except:
- return False
-
- if int(vat[0:7]) < 1:
- return False
- if int(vat[0:7]) > 19999 and int(vat[0:7]) < 1000000:
- return False
- if int(vat[7:9]) > 97:
- return False
- if len(vat) == 10 and int(vat[9]) != 3:
- return False
-
- sum = 8 * int(vat[0]) + 7 * int(vat[1]) + 6 * int(vat[2]) + \
- 5 * int(vat[3]) + 4 * int(vat[4]) + 3 * int(vat[5]) + \
- 2 * int(vat[6]) + 10 * int(vat[7]) + int(vat[8])
- if int(vat[0:3]) > 100:
- if sum % 97 not in (0, 55, 42):
- return False
- else:
- if sum % 97 != 0:
- return False
- return True
- elif len(vat) in (12, 13):
- try:
- int(vat)
- except:
- return False
-
- if int(vat[0:3]) not in (0, 1):
- return False
-
- if int(vat[3:10]) < 1:
- return False
- if int(vat[3:10]) > 19999 and int(vat[3:10]) < 1000000:
- return False
- if int(vat[10:12]) > 97:
- return False
- if len(vat) == 13 and int(vat[12]) != 3:
- return False
-
- sum = 8 * int(vat[3]) + 7 * int(vat[4]) + 6 * int(vat[5]) + \
- 5 * int(vat[6]) + 4 * int(vat[7]) + 3 * int(vat[8]) + \
- 2 * int(vat[9]) + 10 * int(vat[10]) + int(vat[11])
- if sum % 97 != 0:
- return False
- return True
+ __check_vat_ch_re1 = re.compile(r'(MWST|TVA|IVA)[0-9]{6}$')
+ __check_vat_ch_re2 = re.compile(r'E([0-9]{9}|-[0-9]{3}\.[0-9]{3}\.[0-9]{3})(MWST|TVA|IVA)$')
+
+ def check_vat_ch(self, vat):
+ '''
+ Check Switzerland VAT number.
+ '''
+ # VAT number in Switzerland will change between 2011 and 2013
+ # http://www.estv.admin.ch/mwst/themen/00154/00589/01107/index.html?lang=fr
+ # Old format is "TVA 123456" we will admit the user has to enter ch before the number
+ # Format will becomes such as "CHE-999.999.99C TVA"
+ # Both old and new format will be accepted till end of 2013
+ # Accepted format are: (spaces are ignored)
+ # CH TVA ######
+ # CH IVA ######
+ # CH MWST #######
+ #
+ # CHE#########MWST
+ # CHE#########TVA
+ # CHE#########IVA
+ # CHE-###.###.### MWST
+ # CHE-###.###.### TVA
+ # CHE-###.###.### IVA
+ #
+ if self.__check_vat_ch_re1.match(vat):
+ return True
+ match = self.__check_vat_ch_re2.match(vat)
+ if match:
+ # For new TVA numbers, do a mod11 check
+ num = filter(lambda s: s.isdigit(), match.group(1)) # get the digits only
+ factor = (5,4,3,2,7,6,5,4)
+ csum = sum([int(num[i]) * factor[i] for i in range(8)])
+ check = 11 - (csum % 11)
+ return check == int(num[8])