Validation API
Scope
To receive validation data of signed document.
Descriprion
- Validation information is returned for the specified file;
- If the file is not signed, an error message is returned;
Request
The Service provider's application sends the following GET request using TLS:
GET /api-validation/v1.0/{sessionId}/{documentId}/validate
Property | Type | Usage | Description |
---|---|---|---|
sessionId | String (64) | Mandatory | File processing session identifier |
documentId | String (64) | Mandatory | Document identifier, received from "upload" or "list" operation as "id" property |
Authorization
The request must contain an Authorization header with an OAuth Introspect access token obtained via Integration Platform a Service provider's credentials grant flow.
Example
GET /api-validation/v1.0/965af52843d969ab6011c6ba8effbdc307e26517280566ce18a807f37a9029aa/c97823faa1a54658e75207e1a791da2c/validate HTTP/1.1
Authorization: Bearer a477b3a3366768c07e4c458f518711b4b351e8d2c2f0f78a1524e4d3efd00603
Host: signapi-prep.eparaksts.lv
Response
General structure of validation response (JSON object):
{
"data": {
"includedFiles": [
{
"filename": {String}
}
],
"signatureForm": {String},
"signaturesExt": [
{
"id": {String},
"info": {
"bestSignatureTime": {Datetime},
"timestampCreationTime": {Datetime},
"ocspResponseCreationTime": {Datetime},
"timeAssertionMessageImprint": {String},
"signingReason": {String},
"signerRole": [
{
"claimedRole": {String}
}
],
"signatureProductionPlace": {
"countryName": {String},
"stateOrProvince": {String},
"city": {String},
"postalCode": {String}
}
},
"errors": [
{
"content": {String}
}
],
"signedBy": {String},
"warnings": [
{
"content": {String}
}
],
"indication": {String},
"subIndication": {String},
"signatureLevel": {String},
"signatureFormat": {String},
"signerSerialNumber": {String},
"registrationNumber": {String}
}
],
"validationTime": {Datetime},
"signaturesCount": {Number},
"validationLevel": {String},
"validatedDocument": {
"filename": {String}
},
"validSignaturesCount": {Number}
}
}
Property | Description | |
---|---|---|
includedFiles | Array | Information about files included in the ASIC container. |
includedFiles.filename | String | Name of the faile included in the ASIC container. |
signatureForm | String | Format (and optionally version) of the digitally signed document container. |
signaturesExt | Array | Collection of signatures found in digitally signed document |
signaturesExt.id | String | Signature ID attribute |
signaturesExt.info | Object | Object containing trusted signing time information. |
signaturesExt.info.bestSignatureTime | Date | Time value that is regarded as trusted signing time, denoting the earliest time when it can be trusted by the validation application (because proven by some Proof-of-Existence present in the signature) that a signature has existed. The source of the value depends on the signature profile (see also SignatureFormat parameter): - Signature with time-mark (LT_TM level) - the producedAt value of the earliest valid time-mark (OCSP confirmation of the signer's certificate) in the signature. - Signature with time-stamp (LT or LTA level) - the genTime value of the earliest valid signature time-stamp token in the signature. - Signature with BES or EPES level - the value is empty, i.e. there is no trusted signing time value available. |
signaturesExt.signedBy | String | Signature/Seal Creator. CN (common name) value portion in signer's certificate's subject distinguished name |
signaturesExt.errors | Array | Information about validation error(s), array of error messages. |
signaturesExt.warnings | Array | Block of validation warnings that do not affect the overall validation result. |
signaturesExt.indication | String | Overall result of the signature's validation process, according to ETSI EN 319 102-1 "Table 5: Status indications of the signature validation process". Note that the validation results of different signatures in one signed document (signature container) may vary. Possible values: - TOTAL-PASSED - TOTAL-FAILED - INDETERMINATE |
signaturesExt.subindication | String | Additional subindication in case of failed or indeterminate validation result, according to ETSI EN 319 102-1 "Table 6: Validation Report Structure and Semantics" |
signaturesExt.signatureLevel | String | Legal level of the signature, according to Regulation (EU) No 910/2014. - Possible values on positive validation result: - QESIG - QESEAL - QES QES_EDL - "ADES_QC" signature, which according to Latvian Electronic Documents Law is equivalent to a handwritten signature - ADESIG_QC - ADESEAL_QC - ADES_QC - ADESIG - ADESEAL - ADES Possible values on indeterminate validation result: prefix INDETERMINATE is added to the level described in positive result. For example INDETERMINATE_QESIG - Legal level of the signature, according to Regulation (EU) No 910/2014. Possible values on positive validation result: - QESIG - QESEAL - QES QES_EDL - "ADES_QC" signature, which according to Latvian Electronic Documents Law is equivalent to a handwritten signature ADESIG_QC ADESEAL_QC ADES_QC ADESIG ADESEAL ADES Possible values on indeterminate validation result: prefix INDETERMINATE is added to the level described in positive result. For example INDETERMINATE_QESIG Possible values on negative validation result: In addition to abovementioned -NOT_ADES_QC_QSCD -NOT_ADES_QC -NOT_ADES -NA |
signaturesExt.signatureFormat | String | Format and profile (according to Baseline Profile) of the signature. See XAdES Baseline Profile, CAdES Baseline Profile and PAdES Baseline Profile for detailed description of the Baseline Profile levels. Possible values: - XAdES_BASELINE_B - XAdES_BASELINE_B_BES - XAdES_BASELINE_B_EPES - XAdES_BASELINE_T - XAdES_BASELINE_LT - long-term level XAdES signature where time-stamp is used as a assertion of trusted signing time XAdES_BASELINE_LT_TM - long-term level XAdES signature where time-mark is used as a assertion of trusted signing time. - XAdES_BASELINE_LTA - CAdES_BASELINE_B - CAdES_BASELINE_T - CAdES_BASELINE_LT - CAdES_BASELINE_LTA - PAdES_BASELINE_B - PAdES_BASELINE_T - PAdES_BASELINE_LT - PAdES_BASELINE_LTA |
signaturesExt.signerSerialNumber | String | SERIALNUMBER value portion in signer's (natural person) certificate's subject distinguished name. |
signaturesExt.registrationNumber | String | OID 2.5.4.97 (organizationIdentifier) value portion in signer's (legal person) certificate's subject distinguished name. |
validationTime | Date | Time of validating the signature by the service. |
signaturesCount | Number | Number of signatures found inside digitally signed file. |
validSignaturesCount | Number | Signatures count that have validated to TOTAL-PASSED. See also SignatureExt.Indication field. |
validationLevel | String | Validation process against what the document is validated, only applicable on DSS based validations. Possible values: ARCHIVAL_DATA |
validatedDocument | Object | Object containing information about validated document. |
validatedDocument.filename | String | Digitally signed document's file name. |
Example
{
"data": {
"signatureForm": "ASiC-E",
"signaturesExt": [
{
"id": "S1",
"info": {
"bestSignatureTime": "11.11.2019. 08:32:04"
},
"signedBy": "ANDRIS PARAUDZIŅŠ",
"warnings": [
{
"content": "Signature warnings here"
}
],
"indication": "TOTAL-PASSED",
"subindication": "subindication details here"
"signatureLevel": "QESIG",
"signatureFormat": "XAdES_BASELINE_LT",
"signerSerialNumber": "PNOLV-324954-21338"
}
],
"validationTime": "30.12.2019. 06:39",
"signaturesCount": 1,
"validationLevel": "ARCHIVAL_DATA",
"validatedDocument": {
"filename": "test.edoc"
},
"validSignaturesCount": 1
}
}
Updated about 2 years ago