Emissione - API ex-ante/direct
ex-ante/direct vuol dire, come già detto, che occorre fornire in fase di emissione tutte le info relative all'identificazione del titolare e tutti i dati necessari per emettere il certificato.
Chiamata di apertura richiesta di certificato
Per aprire una richiesta di certificato occorre chiamare il servizio:
Il servizio può essere invocato solo con un token TSID di tipo API: operando quindi all'interno di un determinato cliente.
Nella chiamata occorre passare diverse informazioni:
{
"profile": "string",
"rao": {
"certificateAlias": "string",
"alias": "string"
},
"organization": {
"name": "string",
"unit": "string",
"identifier": "string",
"country": "string",
"email": "string",
"processApplication": "string",
"responsibleDocument": "string",
"responsiblePosition": "string"
},
"owner": {
"alias": "string",
"firstName": "string",
"lastName": "string",
"sex": "string",
"birthCity": "string",
"birthCountry": "string",
"birthDate": "2023-07-02",
"birthDistrict": "string",
"city": "string",
"country": "string",
"district": "string",
"cap": "string",
"address": "string",
"email": "string",
"phone": "string",
"pec": "string",
"fiscalCode": "string",
"document": {
"issuer": "string",
"country": "string",
"number": "string",
"releaseDate": "2023-07-02",
"expiryDate": "2023-07-02",
"type": "IDC"
}
}
}
- profile è il nome del profilo di emissione. Contiene tutte le informazioni relative al tipo di certificato, all'identificazione richiesta, alla durata, alle possibili modalità di identificazione, al fatto che richieda o meno un pin etc...
- rao è il Registration Authority Officer, cioè la persona che si assume la responsabilità di emettere il certificato. Normalmente è un rappresentate del cliente. E' necessario fornire il suo alias(identificativo), mentre l'alias del certificato è opzionale. Ha senso solo se il RAO ha più di un certificato associato.
- owner è il titolare del certificato
- organization è l'organizzazione (azienda) per la quale il titolare lavora/opera.
Il servizio esegue una validazione molto stringente dei valori forniti:
| nome | obbligatorio | regex | condizioni | dipendenze |
| owner.firstName | x | [\w\s]{1,128} | ||
| owner.lastName | x | [\w\s]{1,128} | ||
| owner.sex | x | [FMfm]{1} | ||
| owner.birthCity | x | ricavato dal servizio messo a disposizione dalla CA | ||
| owner.birthCountry | x | iso alpha 2 | ||
| owner.birthdate | x | yyyy-MM-dd | >=18 && <=120 anni | |
| owner.birthDistrict | x | ricavato dal servizio messo a disposizione dalla CA | ||
| owner.city | x | ricavato dal servizio messo a disposizione dalla CA | ||
| owner.country | x | iso alpha 2 | ||
| owner.district | x | ricavato dal servizio messo a disposizione dalla CA | ||
| owner.cap | x | [0-9]{3,10} | ||
| owner.address | x | [\w\s]{1,128} | ||
| owner.email | x | si applica reg exp relativa alla mail |
||
| owner.pec | si applica reg exp relativa alla mail |
|||
| owner.phone | x | [+0-9]{8,15} | ||
| owner.fiscalNumber | codice fiscale valido e ricavabile dai valori precedenti | |||
| document.issuer | x | [\w\s]{1,128} | ||
| document.country | x | iso alpha 2 | ||
| document.number | x | si |
||
| document.releaseDate | x | yyyy-MM-dd | <=oggi | |
| document.expiryDate | x | yyyy-MM-dd | >oggi | |
| document.type | x | IDC|PAS|DLC|NLC|PBO|TPL|GUL|IDB | Se fiscalNumber non fornito il type potrà essere solo PAS | |
| organization.name | x | [\w\s]{1,128} | obbligatorio solo per certificati di tipo SEAL | |
| organization.unit | [\w\s]{1,128} | |||
| organization.identifier | x | [\w\s]{1,128} | obbligatorio solo per certificati di tipo SEAL | |
| organization.country | x | iso alpha 2 | obbligatorio solo per certificati di tipo SEAL | |
| organization.email | x | si applica reg exp relativa alla mail |
obbligatorio solo per certificati di tipo SEAL | |
| organization.processApplication | x | [\w\s]{1,128} | obbligatorio solo per certificati di tipo SEAL | |
| organization.responsibleDocument | [\w\s]{1,128} | |||
| organization.responsiblePosition | [\w\s]{1,128} |
Reg exp numero documento, in base al type
Reg exp mail
Data la mail user@domain
{}|~0-9A-Z]+(\\.[-!#$%&'*+/=?^_{}|~0-9A-Z]+)\Z|^"([\001-\010\013\014\016-\037!#-\[\]-\177]|\\[\001-\011\013\014\016-\177])*"\Z)
domain: (?:A-Z0-9?\.)+(?:[A-Z]{2,6}|[A-Z0-9-]{2,}(?<!-))\Z
In risposta il servizio ritorna:
{
"requestId": "64a0895e8620872ba1be33e7",
"document": "JVBERi0xLjYNJeLjz9MNCjQ5NiAwIG9iag0.......2SBV65FF6ic7HWtBZlDsR5T5FuYsFKZgHdlWwD/Rc8BLt/wGjScohDQplbmRzdHJlYW0KZW5kb2JqCnN0YXJ0eHJlZgoyNzg1NTMKJSVFT0YK"
}
- requestId è l'id della richiesta appena aperta
- document è il pdf del modulo di richiesta opportunamente fillato in base 64. Tale modulo deve essere preso in visione dal
titolare
Chiamata di completamento richiesta di certificato
Per completare una richiesta di certificato occorre chiamare il servizio:
Completamento richiesta ex-ante
Il servizio può essere invocato solo con un token TSID di tipo API dello stesso cliente che ha aperto la richiesta.
Nella chiamata occorre passare diverse informazioni:
{
"rao": {
"certificatePin": "12345678"
},
"identificationProcess":"VIDEO",
"identificationDocs": {
},
"extra": {
"pin": "12345678"
},
"webhook": {
"url": "callback_url"
}
}
- rao.certificatePin è pin del certificato del RAO utilizzato per emettere il certificato
- identificationProcess indica il processo di identificazione utilizzato. E' un campo opzionale poichè nel caso di profili con un singolo processo associato questa informazione è ininfluente
- extra.pin è pin che si vuole associare al certificato che si sta emettendo. Ammesso che il certificato necessiti di un pin.
- webhook.url è l'url del webhook che il servizio invocherà per comunicare l'esito dell'operazione. Infatti il servizio in questione è asincrono.
- identificationDocs è la sezione che contiene i documenti di identificazione del titolare. Esistono due modi per fornire i documenti e si rimanda alla sezione relativa
Il servizio, in quanto, asincrono, ritorna un 202 per segnalare la presa in carico dell'operazione.
Ad emissione completata, il servizio avrà cura di:
- inviare al titolare (e se SEAL anche alla mail di organization) una mail con le indicazioni relative al certificato emesso, con in allegato il pdf del modulo di richiesta opportunamente firmato sia dal titolare che dal RAO
- inviare un webhook all'integratore con i dati del certificato
- inviare tutti i documenti prodotti in conservazione
Modalità di caricamento dei documenti di identificazione
In fase di chiamata di completamento
La modalità più semplice è rappresentata dal passaggio dei documenti in fase di chiamata di completamento all'interno del campo identificationDocs:
SPID
"identificationDocs": {
"documents": [
{
"name": "evidences.json",
"data": "JVBERi0xLjYNJeLjz9MNCjQ5NiAwIG9iag08PC9MaW5lYXJpemVkIDEvTCAyNTA1NDQvTyA0OTgvRSAyMTAwNDkvTiAzL1QgMjUwMTE2L0ggWyA3NzEgNDQ5XT4+DWVuZG9iag0gICAgICAgICAgICAgDQo1NjIgMCBvYmoNPDwvRGVjb2RlUGFybXM8PC9Db2x1bW5zIDUvUHJlZGljdG9yIDEyPj4vRmlsdGVyL0ZsYXRlRGVjb2RlL0lEWzwxM0VEQkU4Rjg5NjQ5NjRBODYyNTcwOUIxMEQ1REJFRD48RkIxMTM4OUE0OTI1OEI0Mzg5QUYyNDYzRUY0QUUxRT...."
},
{
"name" : "spid.request.xml",
"data" : "JVBERi0xLjYNJeLjz9MNCjQ5NiAwIG9iag08PC9MaW5lYXJpemVkIDEvTCAyNTA1NDQvTyA0OTgvRSAyMTAwNDkvTiAzL1QgMjUwMTE2L0ggWyA3NzEgNDQ5XT4+DWVuZG9iag0gICAgICAgICAgICAgDQo1NjIgMCBvYmoNPDwvRGVjb2RlUGFybXM8PC9Db2x1bW5zIDUvUHJlZGljdG9yIDEyPj4vRmlsdGVyL0ZsYXRlRGVjb2RlL0lEWzwxM0VEQkU4Rjg5NjQ5NjRBODYyNTcwOUIxMEQ1REJFRD48RkIxMTM4OUE0OTI1OEI0Mzg5QUYyNDYzRUY0QUUxRT...."
},
{
"name" : "spid.response.xml",
"data" : "JVBERi0xLjYNJeLjz9MNCjQ5NiAwIG9iag08PC9MaW5lYXJpemVkIDEvTCAyNTA1NDQvTyA0OTgvRSAyMTAwNDkvTiAzL1QgMjUwMTE2L0ggWyA3NzEgNDQ5XT4+DWVuZG9iag0gICAgICAgICAgICAgDQo1NjIgMCBvYmoNPDwvRGVjb2RlUGFybXM8PC9Db2x1bW5zIDUvUHJlZGljdG9yIDEyPj4vRmlsdGVyL0ZsYXRlRGVjb2RlL0lEWzwxM0VEQkU4Rjg5NjQ5NjRBODYyNTcwOUIxMEQ1REJFRD48RkIxMTM4OUE0OTI1OEI0Mzg5QUYyNDYzRUY0QUUxRT...."
}
]
}
VIDEO
"identificationDocs": {
"documents": [
{
"name": "evidences.json",
"data": "JVBERi0xLjYNJeLjz9MNCjQ5NiAwIG9iag08PC9MaW5lYXJpemVkIDEvTCAyNTA1NDQvTyA0OTgvRSAyMTAwNDkvTiAzL1QgMjUwMTE2L0ggWyA3NzEgNDQ5XT4+DWVuZG9iag0gICAgICAgICAgICAgDQo1NjIgMCBvYmoNPDwvRGVjb2RlUGFybXM8PC9Db2x1bW5zIDUvUHJlZGljdG9yIDEyPj4vRmlsdGVyL0ZsYXRlRGVjb2RlL0lEWzwxM0VEQkU4Rjg5NjQ5NjRBODYyNTcwOUIxMEQ1REJFRD48RkIxMTM4OUE0OTI1OEI0Mzg5QUYyNDYzRUY0QUUxRT...."
}
]
}
FEQ
"identificationDocs": {
"documents": [
{
"name": "request_module.pdf",
"data": "JVBERi0xLjYNJeLjz9MNCjQ5NiAwIG9iag08PC9MaW5lYXJpemVkIDEvTCAyNTA1NDQvTyA0OTgvRSAyMTAwNDkvTiAzL1QgMjUwMTE2L0ggWyA3NzEgNDQ5XT4+DWVuZG9iag0gICAgICAgICAgICAgDQo1NjIgMCBvYmoNPDwvRGVjb2RlUGFybXM8PC9Db2x1bW5zIDUvUHJlZGljdG9yIDEyPj4vRmlsdGVyL0ZsYXRlRGVjb2RlL0lEWzwxM0VEQkU4Rjg5NjQ5NjRBODYyNTcwOUIxMEQ1REJFRD48RkIxMTM4OUE0OTI1OEI0Mzg5QUYyNDYzRUY0QUUxRT...."
}
]
}
Con chiamata separata
Un'altra possibilità è rappresentata dal servizio di caricamento:
Tale metodo ritorna in output una stringa storageFolder che indica il bucket dove i documenti sono stati caricati.
Quindi, in fase di chiamata di completamento, sarà sufficiente andare a fornire tale info all'interno di identificationDocs:
"identificationDocs": {
"storageFolder": "nome"
}