FiscoAPI semplifica l’accesso ai dati fiscali con API affidabili che integrano le informazioni delle Agenzie delle Entrate nelle tue app.
In questa pagina trovi tutte le guide pratiche all'uso. Per ulteriori dettagli, puoi consultare la documentazione completa.
In questa guida vedremo come avviare una sessione autenticata tramite le nostre API per ottenere l’elenco delle fatture emesse associate a una partita IVA.
A seguire, troverai una serie di immagini che mostrano gli step equivalenti che un utente dovrebbe eseguire manualmente sul portale Fatture e Corrispettivi di Agenzia delle Entrate, qualora non utilizzasse le API offerte da FiscoAPI.
Seguendo tutti i passaggi di questa guida, potrai replicare le stesse operazioni viste nel portale dell’Agenzia delle Entrate, ma con importanti vantaggi:
Prima di tutto, accedi al portale di FiscoAPI e nella sezione "Impostazioni", genera una chiave segreta che dovrai utilizzare per creare le chiavi pubbliche usate per l'autenticazione delle API.
Nella stessa sezione devi anche impostare l'endpoint per ricevere gli aggiornamenti in tempo reale tramite webhook. Questo ti permetterà di non dover fare ulteriori chiamate API per vedere i cambi di stato di una sessione.
La chiave segreta non deve essere condivisa con nessuno ma utilizzata solamente dal tuo server, diversamente potrebbe essere utilizzata da altri consumando le tue quote e limiti di utilizzo.
Ora devi creare una chiave pubblica associata alla tua chiave segreta passandola nel body della richiesta /crea_chiave_api
(vedi documentazione).
curl --location --request POST 'https://api.fiscoapi.app/api_esterne/crea_chiave_api' \
--header 'Content-Type: application/json' \
--data-raw '{
"chiave_segreta": "<chiave_segreta>"
}'
Nella risposta riceverai la chiave pubblica e il refresh token.
{
"chiave_pubblica": "<chiave_pubblica>",
"refresh_token": "<refresh_token>",
}
La chiave pubblica ha validità di un ora e può essere ricreata utilizzando il refresh token. Per tutti i dettagli vedi qui.
Utilizzando la chiave pubblica, avvia una sessione scegliendo il tipo di login. Per comodità nell'esempio useremo lo SPID di Poste Italiane. Per tutti gli altri metodi fai riferimento alla documentazione.
curl --location --request POST 'https://api.fiscoapi.app/api_esterne/avvia_sessione' \
--header 'Authorization: Bearer <chiave_pubblica>;' \
--header 'Content-Type: application/json' \
--data-raw '{
"ente": "agenzia_entrate",
"tipo_login": "poste"
}'
Nella risposta riceverai un oggetto di tipo Sessione. Questo è l'oggetto di riferimento che cambierà successivamente stato. Gli aggiornamenti della sessione ti arriveranno tramite webhook o potrai richiedere di nuovo l'oggetto tramite API /sessione:id_sessione.
{
"sessione": {
"ente": "agenzia_entrate",
"tipo_login": "poste",
"data_creazione": 1742983959743,
"id_organization": "643f1a2c9f8b9a1d2e3c4b5a",
"stato": "creazione_form_login",
"_id": "5fa1c3d49b7e6f2a4d8e9c01"
}
}
Da qui in avanti dovrai attendere l'arrivo degli aggiornamenti sul webhook, relativi alla sessione appena avviata, fino allo stato in cui sarà richiesto il login.
La sessione appena avviata passerà diversi stati successivi e quando lo stato sarà richiesta_accesso
dovrai scannerizzare il QR code con l'app di Poste.it che trovi nel campo qr_code
in formato data URL.
Ecco l'esempio di dato che ti arriverà tramite webhook all'endpoint che hai impostato (dettagli in documentazione webhook):
{
"tipo_dato": "Sessione",
"tipo_evento": "update",
"data_invio": 1742983959780,
"dato": {
"ente": "agenzia_entrate",
"tipo_login": "poste",
"data_creazione": 1742983959743,
"id_organization": "643f1a2c9f8b9a1d2e3c4b5a",
"stato": "richiesta_accesso",
"qr_code": "",
"_id": "5fa1c3d49b7e6f2a4d8e9c01"
}
}
Attraverso il data URL potrai visualizzare il QR code al tuo utente o semplicemente aprirlo in una pagina del browser per permettere la scannerizzazione.
Dopo aver effettuato l'accesso, lo stato della sessione cambierà in autenticato
(sempre attraverso aggiornamenti webhook)
e quando lo stato sarà sessione_attiva
potrai iniziare a usare gli utenti che risultano inizializzati.
Con la Sessione in stato sessione_attiva
potrai analizzare quanti servizi sono disponibili per l'utenza con cui hai effettuato l'accesso.
Attualmente i principali sono iva_servizi
e cassetto_fiscale
. In questi campi di
Sessione troverai indicazione sullo stato del servizio.
{
"_id": "5fa1c3d49b7e6f2a4d8e9c01",
"ente": "agenzia_entrate",
"tipo_login": "poste",
"data_creazione": 1743065844435,
"id_organization": "643f1a2c9f8b9a1d2e3c4b5a",
"stato": "sessione_attiva",
"utente_connesso": {
"identificativo": "RSSMRA80A01H501U",
"denominazione": "ROSSI MARIO"
},
"iva_servizi": {
"stato": "disponibile",
"info": {
"utenteAutenticato": {
"nome": "MARIO",
"cognome": "ROSSI",
"cf": "RSSMRA80A01H501U",
"tipo": "FOL"
},
"utenzaLavoro": {
"cf": "10001100101",
"piva": "10001100101",
"denominazione": "MARIO ROSSI SRL",
"tipo": "INCARICO"
}
},
"lista_utenti_lavoro": {
"10001100101": {
"stato": "inizializzato"
},
"20002200202": {
"stato": "da_inizializzare"
}
}
},
"cassetto_fiscale": {
"stato": "disponibile",
"info": {
"utenzaAutenticata": {
"chiaveUtenza": "RSSMRA80A01H501U",
"codiceFiscale": "RSSMRA80A01H501U",
"codiceFiscaleUltimo": "RSSMRA80A01H501U",
"sede": "FOL",
"denominazione": "ROSSI MARIO",
"tipoUtente": "I10"
},
"utenzaDiLavoro": null
},
"lista_utenti_lavoro": {
"10001100101": {
"stato": "da_inizializzare"
},
"20002200202": {
"stato": "da_inizializzare"
},
"RSSMRA80A01H501U": {
"stato": "inizializzato"
}
}
},
"data_avvio": 1743065893276
}
Inoltre, in lista_utenti_lavoro
vedrai tutta la lista di p.iva o codici fiscali associati all'utenza con cui hai effettuato l'accesso.
Ogni procedura di avvio sessione inizializza la prima partita iva o codice fiscale disponibile, se vuoi usarne altri dovrai inizializzarli come indicato
nella prossima guida.
Infatti dall'esempio sopra riportato possiamo vedere che in iva_servizi
:
10001100101
ha il campo stato = inizializzato
ed è quindi pronta all'uso;
20002200202
ha il campo stato = da_inizializzare
che richiede una procedura di inizializzazione per poter essere utilizzata;
Prendendo come riferimento la p.iva 10001100101
che è già disponibile per le chiamate API, puoi richiedere l'elenco fatture emesse tramite il nostro endpoint
GET https://api.fiscoapi.app/api_esterne/fatture_emesse
(vedi documentazione API).
In query url dovrai inserire i seguenti campi:
id_sessione
: il campo _id
della sessione che abbiamo appena avviato (nel nostro caso 5fa1c3d49b7e6f2a4d8e9c01
);
utente_lavoro
: la p.iva dell'utente inizializzato. (nel nostro caso 10001100101
);
inizio
: timestamp in millisecondi di inizio della ricerca;
fine
: timestamp in millisecondi di fine della ricerca;;
curl --location --request GET \
'https://api.fiscoapi.app/api_esterne/fatture_emesse?id_sessione=5fa1c3d49b7e6f2a4d8e9c01&utente_lavoro=10001100101&inizio=<inizio>&fine=<fine>' \
--header 'Authorization: Bearer <chiave_pubblica>'
Nella risposta otterremo l'elenco di fatture emesse (oggetto JSON come restituisce il sito di Agenzia delle Entrate) nel periodo tra ìnizio
e fine
.
{
"fatture": [
{
"variazioni": false,
"fatturePrecedenti": [],
"denominazioneEmittente": "Mario Rossi S.r.l.",
"denominazioneCliente": "Azienda Italiana S.r.l.",
"pivaCliente": "73920101527",
"dataAccoglienzaFile": "2025-03-25",
"identificativoCliente": "73920101527",
"pivaEmittente": "10001100101",
"cfEmittente": "10001100101",
"decodificaTipoInvio": "Fattura tra privati",
"fileDownload": {
"revocaDownload": 0,
"statoDiConsegna": 0,
"statoFile": "Consegnata",
"fileDownload": 1,
"idInvio": "14316399195",
"presaVisione": 0
},
"clienteFornitore": "Fornitore",
"idFattura": "14217767001",
"tipoInvio": "FPR",
"tipoDocumento": "Fattura",
"numeroFattura": "MROSSI-69078",
"dataFattura": "2025-03-25",
"imponibile": "+000000000015,00",
"imposta": "+000000000003,30",
"stato": "Emessa",
"statoVisto": 0,
"dettaglio": true,
"dataConsegna": "25/03/2025",
"testoFattureConsegnate": "Fattura consegnata il 25/03/2025",
"idPaeseCedente": "IT",
"idPaeseCessionario": "IT",
"disclaimer": false,
"disabilitato": false,
"profiloDownload": false
},
{
"variazioni": false,
"fatturePrecedenti": [],
"denominazioneEmittente": "Mario Rossi S.r.l.",
"denominazioneCliente": "Luca Bianchi",
"cfCliente": "BNCLCU90C15F205Z",
"dataAccoglienzaFile": "2025-04-01",
"identificativoCliente": "BNCLCU90C15F205Z",
"pivaEmittente": "10001100101",
"cfEmittente": "10001100101",
"decodificaTipoInvio": "Fattura tra privati",
"fileDownload": {
"revocaDownload": 0,
"statoDiConsegna": 1,
"statoFile": "Mancata consegna",
"fileDownload": 1,
"idInvio": "14362664222",
"presaVisione": 4
},
"clienteFornitore": "Fornitore",
"idFattura": "14217767002",
"tipoInvio": "FPR",
"tipoDocumento": "Fattura",
"numeroFattura": "MROSSI-69716",
"dataFattura": "2025-03-31",
"imponibile": "+000000000000,00",
"imposta": "+000000000000,00",
"stato": "Emessa",
"statoVisto": 0,
"dettaglio": true,
"testoFattureConsegnate": "Fattura non consegnata",
"idPaeseCedente": "IT",
"disclaimer": false,
"disabilitato": false,
"profiloDownload": false
},
...
]
}
Dopo aver avviato una Sessione è possibile effettuare tutte le API che FiscoAPI ti mette a disposizione, come descritto nella documentazione sugli utenti che sono inizializzati.
Se, invece, si vuole utilizzare un'altra p.iva o codice fiscale che non risulta ancora in stato inizializzato
allora sarà necessario effettuare l'inizializzazione come descritto nella prossima guida.
Descriviamo ora la procedura di login con il servizio Namirial come esempio di un processo di avvio Sessione che utilizza credenziali (username e password) e codice OTP inviato tramite specifica app.
La caratteristica principale di tutti i login che richiedono l'accesso con credenziali
è che nella richiesta di avvio Sessione vanno specificati i relativi campi username
e password
.
Quindi avviamo la sessione all'enpoint /api_esterne/avvia_sessione
, utilizzando la chiave pubblica, il tipo login namirial
e i campi
username
e password
(vedi documentazione).
curl --location --request POST 'https://api.fiscoapi.app/api_esterne/avvia_sessione' \
--header 'Authorization: Bearer <chiave_pubblica>;' \
--header 'Content-Type: application/json' \
--data-raw '{
"ente": "agenzia_entrate",
"tipo_login": "namirial",
"username": "<username>"
"password": "<password>"
}'
Nella risposta riceverai un oggetto di tipo Sessione. Questo è l'oggetto di riferimento che cambierà successivamente stato. Gli aggiornamenti della sessione ti arriveranno tramite webhook o potrai richiedere di nuovo l'oggetto tramite API /sessione:id_sessione.
{
"sessione": {
"ente": "agenzia_entrate",
"tipo_login": "namirial",
"data_creazione": 1742983959743,
"id_organization": "643f1a2c9f8b9a1d2e3c4b5a",
"stato": "creazione_form_login",
"_id": "5fa1c3d49b7e6f2a4d8e9c01"
}
}
Ora la sessione in esame cambierà stato successivamente e, essendo nel caso di login con Namirial, attenderai l'arrivo dello stato richiesta_app_otp
,
in cui dovrai scegliere su che app far arrivare il codice OTP per l'accesso.
Ecco l'esempio di dato che ti arriverà tramite webhook all'endpoint che hai impostato (dettagli in documentazione webhook):
{
"tipo_dato": "Sessione",
"tipo_evento": "update",
"data_invio": 1742983959780,
"dato": {
"ente": "agenzia_entrate",
"tipo_login": "poste",
"data_creazione": 1742983959743,
"id_organization": "643f1a2c9f8b9a1d2e3c4b5a",
"stato": "richiesta_app_otp",
"lista_app_otp": [
"189000001",
"189000002"
]
"_id": "5fa1c3d49b7e6f2a4d8e9c01"
}
}
Nel campo lista_app_otp
troverai l'elenco degli ID della app di Namirial che hai installato e dovrai selezionare quella su cui vuoi autorizzare il codice OTP.
In questo caso, di esempio, abbiamo due app con ID 189000001
e 189000002
.
Per selezionare l'app di Namrial, dovrai effettuare una richiesta PATCH /api_esterne/scegli_app_otp
specificando
_id
della sessione in query url (vedi documentazione).
Nel body
della richiesta specificherai l'id dell'app scelta, per esempio 189000001
,
nel campo app_otp_selezionata
.
curl --location --request PATCH 'https://api.fiscoapi.app/api_esterne/scegli_app_otp/5fa1c3d49b7e6f2a4d8e9c01' \
--header 'Authorization: Bearer <chiave_pubblica>;' \
--header 'Content-Type: application/json' \
--data-raw '{
"app_otp_selezionata": "189000001"
}'
In risposta verrà ritornato sempre un oggetto di tipo Sessione e, sempre tramite webhook,
attenderai la richiesta di inserimento codice OTP quando la sessione sarà in stato richiesta_codice_otp
.
Nel frattempo sull'app di Namirial arriverà una notifica di generezaione codice OTP.
Quando la Sessione sarà in stato richiesta_codice_otp
dovrai inserire il codice fornito tramite app di Namirial.
Per invia il codice OTP, dovrai effettuare una richiesta PATCH /api_esterne/invia_codice_otp
specificando
_id
della sessione in query url (vedi documentazione).
Nel body
della richiesta specificherai il codice OTP che ti ha fornito l'app,
nel campo codice_otp
.
curl --location --request PATCH 'https://api.fiscoapi.app/api_esterne/invia_codice_otp/5fa1c3d49b7e6f2a4d8e9c01' \
--header 'Authorization: Bearer <chiave_pubblica>;' \
--header 'Content-Type: application/json' \
--data-raw '{
"codice_otp": <codice_otp>"
}'
In risposta verrà ritornato sempre un oggetto di tipo Sessione e, sempre tramite webhook,
attenderai che la sessione risulti in stato sessione_attiva
. Da questo momento in poi, potrai utilizzare questa sessione per tutte le richieste
come indicato nella quickstart guide.
In questa guida verrà spiegato il processo di inizializzazione di un utente lavoro, ovvero di una p.iva o codice fiscale non ancora in stato inizializzato
.
A seguire, troverai una serie di immagini che mostrano gli step equivalenti che un utente dovrebbe eseguire manualmente sul portale Fatture e Corrispettivi per cambiare la p.iva (utente lavoro), qualora non utilizzasse le API offerte da FiscoAPI.
Seguendo tutti i passaggi di questa guida, potrai replicare le stesse operazioni viste nel portale dell’Agenzia delle Entrate.
Per inizializzare un utente lavoro su un servizio della sessione attiva devi utilizzare l'API con endpoint
PATCH /inizializza_utente_lavoro
(vedi documentazione).
Quindi prendendo in esame l'esempio della guida precedente e ipotizzando di voler inizializzare la p.iva 20002200202
nella nostra sessione per
iva_servizi
:
{
"_id": "5fa1c3d49b7e6f2a4d8e9c01",
"ente": "agenzia_entrate",
"tipo_login": "poste",
"data_creazione": 1743065844435,
"id_organization": "643f1a2c9f8b9a1d2e3c4b5a",
"stato": "sessione_attiva",
"utente_connesso": {
"identificativo": "RSSMRA80A01H501U",
"denominazione": "ROSSI MARIO"
},
"iva_servizi": {
"stato": "disponibile",
"info": {
"utenteAutenticato": {
"nome": "MARIO",
"cognome": "ROSSI"
"cf": "RSSMRA80A01H501U",
"tipo": "FOL"
},
"utenzaLavoro": {
"cf": "10001100101",
"piva": "10001100101",
"denominazione": "MARIO ROSSI SRL",
"tipo": "INCARICO"
}
},
"lista_utenti_lavoro": {
"10001100101": {
"stato": "inizializzato"
},
"20002200202": {
"stato": "da_inizializzare"
}
}
},
"cassetto_fiscale": {
"stato": "disponibile",
"info": {
"utenzaAutenticata": {
"chiaveUtenza": "RSSMRA80A01H501U",
"codiceFiscale": "RSSMRA80A01H501U",
"codiceFiscaleUltimo": "RSSMRA80A01H501U",
"sede": "FOL",
"denominazione": "ROSSI MARIO",
"tipoUtente": "I10"
},
"utenzaDiLavoro": null
},
"lista_utenti_lavoro": {
"10001100101": {
"stato": "da_inizializzare"
},
"20002200202": {
"stato": "da_inizializzare"
},
"RSSMRA80A01H501U": {
"stato": "inizializzato"
}
}
},
"data_avvio": 1743065893276
}
I parametri necessari per la PATCH sono:
id_sessione
: il campo _id
della sessione che abbiamo avviato nella guida precedente (nel nostro caso 5fa1c3d49b7e6f2a4d8e9c01
) che va messo come parametro nell'URL;
servizio
: il nome del servizio per cui si vuole inizializzare l'utente (nel nostro caso iva_servizi
come da campo di Sessione);
utente_lavoro
: partita iva o codice fiscale dell'utente lavoro che si vuole inizializzare (nel nostro caso 20002200202
);
curl --location --request PATCH 'https://api.fiscoapi.app/api_esterne/inizializza_utente_lavoro/<id_sessione>' \
--header 'Authorization: Bearer <chiave_pubblica>' \
--header 'Content-Type: application/json' \
--data-raw '{
"servizio": "iva_servizi",
"utente_lavoro": "20002200202"
}'
La risposta di questa richiesta sarà il solito oggetto Sessione
con lo stato dell'utente lavoro in_inizializzazione
.
Sempre attraverso aggiornamento tramite webhook al tuo endpoint riceverai un update di Sessione
quando l'inizializzazione utente sarà completata. Il suo stato sarà: inizializzato
.
Ecco l'esempio di dato che ti arriverà tramite webhook all'endpoint che hai impostato (dettagli in documentazione webhook):
{
"_id": "5fa1c3d49b7e6f2a4d8e9c01",
"ente": "agenzia_entrate",
"tipo_login": "poste",
"data_creazione": 1743065844435,
"id_organization": "643f1a2c9f8b9a1d2e3c4b5a",
"stato": "sessione_attiva",
"utente_connesso": {
"identificativo": "RSSMRA80A01H501U",
"denominazione": "ROSSI MARIO"
},
"iva_servizi": {
"stato": "disponibile",
"info": {
"utenteAutenticato": {
"nome": "MARIO",
"cognome": "ROSSI",
"cf": "RSSMRA80A01H501U",
"tipo": "FOL"
},
"utenzaLavoro": {
"cf": "10001100101",
"piva": "10001100101",
"denominazione": "MARIO ROSSI SRL",
"tipo": "INCARICO"
}
},
"lista_utenti_lavoro": {
"10001100101": {
"stato": "inizializzato"
},
"20002200202": {
"stato": "inizializzato"
}
}
},
"cassetto_fiscale": {
"stato": "disponibile",
"info": {
"utenzaAutenticata": {
"chiaveUtenza": "RSSMRA80A01H501U",
"codiceFiscale": "RSSMRA80A01H501U",
"codiceFiscaleUltimo": "RSSMRA80A01H501U",
"sede": "FOL",
"denominazione": "ROSSI MARIO",
"tipoUtente": "I10"
},
"utenzaDiLavoro": null
},
"lista_utenti_lavoro": {
"10001100101": {
"stato": "da_inizializzare"
},
"20002200202": {
"stato": "da_inizializzare"
},
"RSSMRA80A01H501U": {
"stato": "inizializzato"
}
}
},
"data_avvio": 1743065893276
}
Da qui in avanti potrai usare 20002200202
sul servizio iva_servizi
nella tua sessione.
Per esempio come abbiamo fatto con 10001100101
nella ricerca fatture emesse o
in qualsiasi altra API della documentazione.