@arseniosiani/cfjs
v1.0.5
Published
Modulo nodejs che il effettua il check/creazione/parsing del Codice Fiscale italiano
Downloads
34
Maintainers
Readme
cfjs
Modulo nodejs che il effettua il check/creazione/parsing del Codice Fiscale italiano, l'elenco dei comuni italiani viene aggiornato dal repo di matteocontrini; buona parte della logica proviene dal repo di lucavandro
Semplice e diretto!
Intallation
npm i @arseniosiani/cfjs --save
Usage
const cfjs = require('@arseniosiani/cfjs');
let infos = cfjs.parse("RSSMRA72L09H501S");
console.log(infos);
// {
// nome: 'MARIO',
// cognome: 'ROSSI',
// sesso: 'M',
// data_nascita: '1972-07-09',
// comune_nascita: 'Roma',
// provincia_nascita: 'RM',
// cap_nascita: '00118',
// cod_catastale_nascita: 'H501'
// }
// =========================================
let cf = cfjs.stringify({
nome: 'MARIO',
cognome: 'ROSSI',
sesso: 'M',
data_nascita: '1972-07-09',
comune_nascita: 'Roma',
provincia_nascita: 'RM',
cap_nascita: '00118',
cod_catastale_nascita: 'H501'
});
console.log(cf); // RSSMRA72L09H501S
let is_valid = cfjs.check("RSSMRA72L09H501S");
console.log(is_valid); // true
È possibile calcolare il Codice fiscale indicando anche solo alcune informazioni del luogo di nascita:
let cf = cfjs.stringify({
nome: 'MARIO',
cognome: 'ROSSI',
sesso: 'M',
data_nascita: '1972-07-09',
cap_nascita: '00118', // solo CAP
});
console.log(cf); // RSSMRA72L09H501S
// =========================================
let cf = cfjs.stringify({
nome: 'MARIO',
cognome: 'ROSSI',
sesso: 'M',
data_nascita: '1972-07-09',
cod_catastale_nascita: 'H501' // solo codice catastale
});
console.log(cf); // RSSMRA72L09H501S
Funziona anche con i Codici fiscali generati su soggetti nati all'estero
I codici catastali esteri e i relativi nomi di nazioni sono aggiornati dal sito istat
const cfjs = require('@arseniosiani/cfjs')
let infos = cfjs.parse("RSSMRA72L09Z247X")
console.log(infos);
// {
// nome: 'MRA',
// cognome: 'RSS',
// sesso: 'M',
// data_nascita: '1972-07-09',
// comune_nascita: 'Malaysia', <- Stato estero nel campo del comune
// provincia_nascita: 'EE', <- EE come provincia di nascita
// cap_nascita: '', <- CAP di nascita sempre vuoto
// cod_catastale_nascita: 'Z247'
// }
// =========================================
let cf = cfjs.stringify({
nome: 'MARIO',
cognome: 'ROSSI',
sesso: 'M',
data_nascita: '1972-07-09',
comune_nascita: 'Germania' // stato estero
})
console.log(cf); // RSSMRA72L09Z112D
Implementa anche la generazione degli omocodici:
const cfjs = require('@arseniosiani/cfjs')
let omocodes = cfjs.getOmocodes("RSSMRA72L09Z247X")
console.log(omocodes)
// [
// 'RSSMRA72L09Z2QTG',
// 'RSSMRA72L09ZNQTV',
// 'RSSMRA72L0VZNQTK',
// 'RSSMRA72LLVZNQTV',
// 'RSSMRA7NLLVZNQTG',
// 'RSSMRATNLLVZNQTD',
// 'RSSMRA72L09Z24TU',
// 'RSSMRA72L09Z24TU'
// ]