UNPKG

stdnum

Version:
73 lines (60 loc) 1.83 kB
/** * * DNI (Documento Nacional de Identidad, Argentinian national identity nr.). * * The DNI number is the number that appears on the Argentinian national * identity document and is used to identify citizen and foreigners residing in * the country. * * Sources: * https://en.wikipedia.org/wiki/Documento_Nacional_de_Identidad_(Argentina) * * PERSON */ import * as exceptions from '../exceptions'; import { ValidateReturn, Validator } from '../types'; import { strings } from '../util'; function clean(input: string): ReturnType<typeof strings.cleanUnicode> { return strings.cleanUnicode(input, ' .'); } const impl: Validator = { name: 'Argentinian National Identity Document', localName: 'Documento Nacional de Identidad', abbreviation: 'DNI', compact(input: string): string { const [value, err] = clean(input); if (err) { throw err; } return value; }, format(input: string): string { const [value] = clean(input); return strings.splitAt(value, value.length - 6, value.length - 3).join('.'); }, /** * Check if the number is a valid DNI number. * This checks the length, formatting and other contraints. It does not check * for control letter. */ validate(input: string): ValidateReturn { const [value, error] = clean(input); if (error) { return { isValid: false, error }; } if (value.length !== 7 && value.length !== 8) { return { isValid: false, error: new exceptions.InvalidLength() }; } if (!strings.isdigits(value)) { return { isValid: false, error: new exceptions.InvalidComponent() }; } return { isValid: true, compact: value, isIndividual: true, isCompany: false, }; }, }; export const { name, localName, abbreviation, validate, format, compact } = impl;