isPassportNumber.js 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.default = isPassportNumber;
  6. var _assertString = _interopRequireDefault(require("./util/assertString"));
  7. function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
  8. /**
  9. * Reference:
  10. * https://en.wikipedia.org/ -- Wikipedia
  11. * https://docs.microsoft.com/en-us/microsoft-365/compliance/eu-passport-number -- EU Passport Number
  12. * https://countrycode.org/ -- Country Codes
  13. */
  14. var passportRegexByCountryCode = {
  15. AM: /^[A-Z]{2}\d{7}$/,
  16. // ARMENIA
  17. AR: /^[A-Z]{3}\d{6}$/,
  18. // ARGENTINA
  19. AT: /^[A-Z]\d{7}$/,
  20. // AUSTRIA
  21. AU: /^[A-Z]\d{7}$/,
  22. // AUSTRALIA
  23. BE: /^[A-Z]{2}\d{6}$/,
  24. // BELGIUM
  25. BG: /^\d{9}$/,
  26. // BULGARIA
  27. BR: /^[A-Z]{2}\d{6}$/,
  28. // BRAZIL
  29. BY: /^[A-Z]{2}\d{7}$/,
  30. // BELARUS
  31. CA: /^[A-Z]{2}\d{6}$/,
  32. // CANADA
  33. CH: /^[A-Z]\d{7}$/,
  34. // SWITZERLAND
  35. CN: /^[GE]\d{8}$/,
  36. // CHINA [G=Ordinary, E=Electronic] followed by 8-digits
  37. CY: /^[A-Z](\d{6}|\d{8})$/,
  38. // CYPRUS
  39. CZ: /^\d{8}$/,
  40. // CZECH REPUBLIC
  41. DE: /^[CFGHJKLMNPRTVWXYZ0-9]{9}$/,
  42. // GERMANY
  43. DK: /^\d{9}$/,
  44. // DENMARK
  45. DZ: /^\d{9}$/,
  46. // ALGERIA
  47. EE: /^([A-Z]\d{7}|[A-Z]{2}\d{7})$/,
  48. // ESTONIA (K followed by 7-digits), e-passports have 2 UPPERCASE followed by 7 digits
  49. ES: /^[A-Z0-9]{2}([A-Z0-9]?)\d{6}$/,
  50. // SPAIN
  51. FI: /^[A-Z]{2}\d{7}$/,
  52. // FINLAND
  53. FR: /^\d{2}[A-Z]{2}\d{5}$/,
  54. // FRANCE
  55. GB: /^\d{9}$/,
  56. // UNITED KINGDOM
  57. GR: /^[A-Z]{2}\d{7}$/,
  58. // GREECE
  59. HR: /^\d{9}$/,
  60. // CROATIA
  61. HU: /^[A-Z]{2}(\d{6}|\d{7})$/,
  62. // HUNGARY
  63. IE: /^[A-Z0-9]{2}\d{7}$/,
  64. // IRELAND
  65. IN: /^[A-Z]{1}-?\d{7}$/,
  66. // INDIA
  67. IR: /^[A-Z]\d{8}$/,
  68. // IRAN
  69. IS: /^(A)\d{7}$/,
  70. // ICELAND
  71. IT: /^[A-Z0-9]{2}\d{7}$/,
  72. // ITALY
  73. JP: /^[A-Z]{2}\d{7}$/,
  74. // JAPAN
  75. KR: /^[MS]\d{8}$/,
  76. // SOUTH KOREA, REPUBLIC OF KOREA, [S=PS Passports, M=PM Passports]
  77. LT: /^[A-Z0-9]{8}$/,
  78. // LITHUANIA
  79. LU: /^[A-Z0-9]{8}$/,
  80. // LUXEMBURG
  81. LV: /^[A-Z0-9]{2}\d{7}$/,
  82. // LATVIA
  83. LY: /^[A-Z0-9]{8}$/,
  84. // LIBYA
  85. MT: /^\d{7}$/,
  86. // MALTA
  87. MZ: /^([A-Z]{2}\d{7})|(\d{2}[A-Z]{2}\d{5})$/,
  88. // MOZAMBIQUE
  89. MY: /^[AHK]\d{8}$/,
  90. // MALAYSIA
  91. NL: /^[A-Z]{2}[A-Z0-9]{6}\d$/,
  92. // NETHERLANDS
  93. PO: /^[A-Z]{2}\d{7}$/,
  94. // POLAND
  95. PT: /^[A-Z]\d{6}$/,
  96. // PORTUGAL
  97. RO: /^\d{8,9}$/,
  98. // ROMANIA
  99. RU: /^\d{2}\d{2}\d{6}$/,
  100. // RUSSIAN FEDERATION
  101. SE: /^\d{8}$/,
  102. // SWEDEN
  103. SL: /^(P)[A-Z]\d{7}$/,
  104. // SLOVANIA
  105. SK: /^[0-9A-Z]\d{7}$/,
  106. // SLOVAKIA
  107. TR: /^[A-Z]\d{8}$/,
  108. // TURKEY
  109. UA: /^[A-Z]{2}\d{6}$/,
  110. // UKRAINE
  111. US: /^\d{9}$/ // UNITED STATES
  112. };
  113. /**
  114. * Check if str is a valid passport number
  115. * relative to provided ISO Country Code.
  116. *
  117. * @param {string} str
  118. * @param {string} countryCode
  119. * @return {boolean}
  120. */
  121. function isPassportNumber(str, countryCode) {
  122. (0, _assertString.default)(str);
  123. /** Remove All Whitespaces, Convert to UPPERCASE */
  124. var normalizedStr = str.replace(/\s/g, '').toUpperCase();
  125. return countryCode.toUpperCase() in passportRegexByCountryCode && passportRegexByCountryCode[countryCode].test(normalizedStr);
  126. }
  127. module.exports = exports.default;
  128. module.exports.default = exports.default;