standardizide the response
This commit is contained in:
		| @@ -24,7 +24,7 @@ When the request is complete, the server returns a JSON object with this structu | ||||
|  | ||||
|     { | ||||
|       "signature": { | ||||
|         "valid": true, | ||||
|         "valid": true | ||||
|       }, | ||||
|       "valid": { | ||||
|         "valid": true, | ||||
|   | ||||
							
								
								
									
										245
									
								
								apigreen.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										245
									
								
								apigreen.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,245 @@ | ||||
| { | ||||
|   "openapi": "3.0.0", | ||||
|   "info": { | ||||
|     "contact": { | ||||
|       "name": "Gianmarco Pettianto", | ||||
|       "email": "gianmarco@pettinato.eu", | ||||
|       "url": "jatus.tech" | ||||
|     }, | ||||
|     "description": "Endpoint for DGC server", | ||||
|     "title": "green", | ||||
|     "version": "1.0" | ||||
|   }, | ||||
|   "servers": [ | ||||
|     { | ||||
|       "url": "http://localhost:3000" | ||||
|     } | ||||
|   ], | ||||
|   "paths": { | ||||
|     "/api/green": { | ||||
|       "post": { | ||||
|         "tags": [], | ||||
|         "summary": "Sends a request of testing", | ||||
|         "operationId": "post-certificate", | ||||
|         "description": "Checks the greenpass raw data", | ||||
|         "parameters": [], | ||||
|         "responses": { | ||||
|           "200": { | ||||
|             "description": "OK", | ||||
|             "content": { | ||||
|               "application/json": { | ||||
|                 "schema": { | ||||
|                   "$ref": "#/components/schemas/Valid-response" | ||||
|                 }, | ||||
|                 "examples": { | ||||
|                   "Valid certificate response": { | ||||
|                     "value": { | ||||
|                       "signature": { | ||||
|                         "valid": true | ||||
|                       }, | ||||
|                       "valid": { | ||||
|                         "valid": true, | ||||
|                         "message": "Certificate is valid" | ||||
|                       }, | ||||
|                       "info": { | ||||
|                         "identity": { | ||||
|                           "fnt": "ROSSI", | ||||
|                           "fn": "ROSSI", | ||||
|                           "gnt": "MARIO", | ||||
|                           "gn": "MARIO" | ||||
|                         }, | ||||
|                         "dob": "1973-06-22" | ||||
|                       } | ||||
|                     } | ||||
|                   }, | ||||
|                   "expired certificate": { | ||||
|                     "value": { | ||||
|                       "signature": { | ||||
|                         "valid": true | ||||
|                       }, | ||||
|                       "valid": { | ||||
|                         "valid": false, | ||||
|                         "message": "Certificate is not valid" | ||||
|                       }, | ||||
|                       "info": { | ||||
|                         "identity": { | ||||
|                           "fnt": "ROSSI", | ||||
|                           "fn": "ROSSI", | ||||
|                           "gnt": "MARIO", | ||||
|                           "gn": "MARIO" | ||||
|                         }, | ||||
|                         "dob": "1973-06-22" | ||||
|                       } | ||||
|                     } | ||||
|                   }, | ||||
|                   "Certificate not  yet valid": { | ||||
|                     "value": { | ||||
|                       "signature": { | ||||
|                         "valid": true | ||||
|                       }, | ||||
|                       "valid": { | ||||
|                         "valid": false, | ||||
|                         "message": "Certificate is not valid yet" | ||||
|                       }, | ||||
|                       "info": { | ||||
|                         "identity": { | ||||
|                           "fnt": "ROSSI", | ||||
|                           "fn": "ROSSI", | ||||
|                           "gnt": "MARIO", | ||||
|                           "gn": "MARIO" | ||||
|                         }, | ||||
|                         "dob": "1973-06-22" | ||||
|                       } | ||||
|                     } | ||||
|                   }, | ||||
|                   "Invalid signature": { | ||||
|                     "value": { | ||||
|                       "signature": { | ||||
|                         "valid": false | ||||
|                       }, | ||||
|                       "valid": { | ||||
|                         "valid": false, | ||||
|                         "message": "Certificate is not valid yet" | ||||
|                       }, | ||||
|                       "info": { | ||||
|                         "identity": { | ||||
|                           "fnt": "ROSSI", | ||||
|                           "fn": "ROSSI", | ||||
|                           "gnt": "MARIO", | ||||
|                           "gn": "MARIO" | ||||
|                         }, | ||||
|                         "dob": "1973-06-22" | ||||
|                       } | ||||
|                     } | ||||
|                   }, | ||||
|                   "Invalid certificate": { | ||||
|                     "value": { | ||||
|                       "signature": { | ||||
|                         "valid": false | ||||
|                       }, | ||||
|                       "valid": { | ||||
|                         "valid": false, | ||||
|                         "message": "" | ||||
|                       }, | ||||
|                       "info": { | ||||
|                         "identity": { | ||||
|                           "fnt": "", | ||||
|                           "fn": "", | ||||
|                           "gnt": "", | ||||
|                           "gn": "" | ||||
|                         }, | ||||
|                         "dob": "" | ||||
|                       } | ||||
|                     } | ||||
|                   } | ||||
|                 } | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   "components": { | ||||
|     "schemas": { | ||||
|       "Valid-response": { | ||||
|         "description": "", | ||||
|         "type": "object", | ||||
|         "x-examples": { | ||||
|           "example-1": { | ||||
|             "signature": { | ||||
|               "valid": true | ||||
|             }, | ||||
|             "valid": { | ||||
|               "valid": true, | ||||
|               "message": "Certificate is valid" | ||||
|             }, | ||||
|             "info": { | ||||
|               "identity": { | ||||
|                 "fnt": "ROSSI", | ||||
|                 "fn": "ROSSI", | ||||
|                 "gnt": "MARIO", | ||||
|                 "gn": "MARIO" | ||||
|               }, | ||||
|               "dob": "1973-06-22" | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         "properties": { | ||||
|           "signature": { | ||||
|             "type": "object", | ||||
|             "required": [ | ||||
|               "valid" | ||||
|             ], | ||||
|             "properties": { | ||||
|               "valid": { | ||||
|                 "type": "boolean" | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|           "valid": { | ||||
|             "type": "object", | ||||
|             "required": [ | ||||
|               "valid", | ||||
|               "message" | ||||
|             ], | ||||
|             "properties": { | ||||
|               "valid": { | ||||
|                 "type": "boolean" | ||||
|               }, | ||||
|               "message": { | ||||
|                 "type": "string", | ||||
|                 "minLength": 1 | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|           "info": { | ||||
|             "type": "object", | ||||
|             "required": [ | ||||
|               "identity", | ||||
|               "dob" | ||||
|             ], | ||||
|             "properties": { | ||||
|               "identity": { | ||||
|                 "type": "object", | ||||
|                 "required": [ | ||||
|                   "fnt", | ||||
|                   "fn", | ||||
|                   "gnt", | ||||
|                   "gn" | ||||
|                 ], | ||||
|                 "properties": { | ||||
|                   "fnt": { | ||||
|                     "type": "string", | ||||
|                     "minLength": 1 | ||||
|                   }, | ||||
|                   "fn": { | ||||
|                     "type": "string", | ||||
|                     "minLength": 1 | ||||
|                   }, | ||||
|                   "gnt": { | ||||
|                     "type": "string", | ||||
|                     "minLength": 1 | ||||
|                   }, | ||||
|                   "gn": { | ||||
|                     "type": "string", | ||||
|                     "minLength": 1 | ||||
|                   } | ||||
|                 } | ||||
|               }, | ||||
|               "dob": { | ||||
|                 "type": "string", | ||||
|                 "minLength": 1 | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         "required": [ | ||||
|           "signature", | ||||
|           "valid", | ||||
|           "info" | ||||
|         ] | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @@ -2,7 +2,7 @@ import dayjs from 'dayjs'; | ||||
| import utc from 'dayjs/plugin/utc'; | ||||
| import timezone from 'dayjs/plugin/timezone'; | ||||
|  | ||||
| interface checkResult { | ||||
| export interface CheckResult { | ||||
|   valid: boolean; | ||||
|   message: string; | ||||
| } | ||||
| @@ -26,7 +26,7 @@ export class VaccineVerifier { | ||||
|   settings=[]; | ||||
|   certTypes=['r','v','t',] | ||||
|  | ||||
|   private checkVaccine = (payload:any):checkResult => { | ||||
|   private checkVaccine = (payload:any):CheckResult => { | ||||
|     const inoculationDate = dayjs(payload.dt); | ||||
|     const validRulesSet = this.getRulesSet(payload.mp); | ||||
|     const vaccineDiff = payload.sd - payload.dn; | ||||
| @@ -40,17 +40,17 @@ export class VaccineVerifier { | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   private checkRecovery = (payload:any):checkResult => { | ||||
|   private checkRecovery = (payload:any):CheckResult => { | ||||
|     const now = dayjs(); | ||||
|     const dateFrom = dayjs(payload.df); | ||||
|     const dateEnd = dayjs(payload.du); | ||||
|     if(now.isAfter(dateFrom) && now.isBefore(dateEnd)){ | ||||
|       return{valid:true, message:'Certificate is valid'}; | ||||
|     } | ||||
|     return {valid:false, message:'toimplement'}; | ||||
|     return {valid:false, message:'Certificate is not valid'}; | ||||
|   } | ||||
|  | ||||
|   private checkTest = (payload:any):checkResult => { | ||||
|   private checkTest = (payload:any):CheckResult => { | ||||
|     const validRulesSet = this.getRulesSet('GENERIC'); | ||||
|     const testType = payload.tt; | ||||
|     if(payload.tr === this.positiveTest) | ||||
| @@ -77,10 +77,9 @@ export class VaccineVerifier { | ||||
|     this.settings = settings; | ||||
|   } | ||||
|  | ||||
|   public checkCertifcate(pass:unknown):checkResult { | ||||
|     console.log(pass); | ||||
|   public checkCertifcate(pass:unknown):CheckResult { | ||||
|     const certificateDataAndType = this.getCertificateData(pass); | ||||
|     const result: checkResult = this.functionSelector[certificateDataAndType.key](certificateDataAndType.certificateData); | ||||
|     const result: CheckResult = this.functionSelector[certificateDataAndType.key](certificateDataAndType.certificateData); | ||||
|     return result; | ||||
|   } | ||||
|  | ||||
| @@ -103,25 +102,25 @@ export class VaccineVerifier { | ||||
|     }); | ||||
|   } | ||||
|  | ||||
|   private getLogicValidityDays(validRulesSet:unknown[],startKey:string, endKey:string, inoculationDate: dayjs.Dayjs): checkResult { | ||||
|   private getLogicValidityDays(validRulesSet:unknown[],startKey:string, endKey:string, inoculationDate: dayjs.Dayjs): CheckResult { | ||||
|     const now = dayjs(); | ||||
|     const ruleStart = validRulesSet.find((elem:any)=>{return elem.name == startKey;}); | ||||
|     const ruleEnd = validRulesSet.find((elem:any)=>{return elem.name == endKey;}); | ||||
|     const startValidity = inoculationDate.add(parseInt(ruleStart['value']),'days'); | ||||
|     const endValidity = inoculationDate.add(parseInt(ruleEnd['value']),'days'); | ||||
|     if(startValidity.isAfter(now)) return {valid:false, message:'Certificate not yet valid'}; | ||||
|     if(now.isAfter(endValidity)) return {valid:false, message:'Certificate not more valid'}; | ||||
|     if(startValidity.isAfter(now)) return {valid:false, message:'Certificate is not valid yet'}; | ||||
|     if(now.isAfter(endValidity)) return {valid:false, message:'Certificate is not valid'}; | ||||
|     return {valid:true, message:'Certificate is valid'}; | ||||
|   } | ||||
|  | ||||
|   private getLogicValidityHours(validRulesSet:unknown[],startKey:string, endKey:string, inoculationDate: dayjs.Dayjs): checkResult { | ||||
|   private getLogicValidityHours(validRulesSet:unknown[],startKey:string, endKey:string, inoculationDate: dayjs.Dayjs): CheckResult { | ||||
|     const now = dayjs(); | ||||
|     const ruleStart = validRulesSet.find((elem:any)=>{return elem.name == startKey;}); | ||||
|     const ruleEnd = validRulesSet.find((elem:any)=>{return elem.name == endKey;}); | ||||
|     const startValidity = inoculationDate.add(parseInt(ruleStart['value']),'hours'); | ||||
|     const endValidity = inoculationDate.add(parseInt(ruleEnd['value']),'hours'); | ||||
|     if(startValidity.isAfter(now)) return {valid:false, message:'Certificate not yet valid'}; | ||||
|     if(now.isAfter(endValidity)) return {valid:false, message:'Certificate not more valid'}; | ||||
|     if(startValidity.isAfter(now)) return {valid:false, message:'Certificate is not valid yet'}; | ||||
|     if(now.isAfter(endValidity)) return {valid:false, message:'Certificate is not valid'}; | ||||
|     return {valid:true, message:'Certificate is valid'}; | ||||
|   } | ||||
|  | ||||
|   | ||||
| @@ -1,8 +1,23 @@ | ||||
| import { CertificateDownloader } from '../SettingsDownloader/CertificateDownloader'; | ||||
| import { RuleDownloader } from '../SettingsDownloader/RuleDownloader'; | ||||
| import { VaccineVerifier } from './VaccineVerifier'; | ||||
| import { CheckResult, VaccineVerifier } from './VaccineVerifier'; | ||||
| import {DCC} from 'dcc-utils'; | ||||
| import jsrsasign from 'jsrsasign'; | ||||
| interface certificateResponse { | ||||
|   signature:{ | ||||
|     valid: boolean | ||||
|   }, | ||||
|   valid:CheckResult, | ||||
|   info:{ | ||||
|     identity:{ | ||||
|       fnt:string, | ||||
|       fn:string, | ||||
|       gnt:string, | ||||
|       gn:string | ||||
|     }, | ||||
|     dob:string | ||||
|   } | ||||
| } | ||||
| export default class Verifier { | ||||
|   static instance: Verifier|undefined  =  undefined; | ||||
|   private certDownloader: CertificateDownloader; | ||||
| @@ -22,12 +37,16 @@ export default class Verifier { | ||||
|     return Verifier.instance; | ||||
|   } | ||||
|    | ||||
|   async checkCertificate(certificate:string): Promise<unknown>{ | ||||
|   async checkCertificate(certificate:string): Promise<certificateResponse>{ | ||||
|     let result:certificateResponse = {signature:{valid: false}, valid:{valid:false, message:''}, info:{identity:{fnt:'',fn:'',gnt:'',gn:''},dob:''}}; | ||||
|     try { | ||||
|       const dcc = await DCC.fromRaw(certificate); | ||||
|     let result:unknown = {}; | ||||
|     result = await (await this.checkKey(dcc)).valid; | ||||
|       const signatureValidity = (await this.checkKey(dcc)).valid; | ||||
|       const vaccineVerifier = new VaccineVerifier(await this.ruleDownloader.getRules()); | ||||
|     result = {signature: result, valid:  vaccineVerifier.checkCertifcate(dcc.payload), info:{identity:dcc.payload.nam,dob:dcc.payload.dob}}; | ||||
|       result = {signature:{valid: signatureValidity}, valid:  vaccineVerifier.checkCertifcate(dcc.payload), info:{identity:dcc.payload.nam,dob:dcc.payload.dob}}; | ||||
|     } catch (error) { | ||||
|       console.log(error); | ||||
|     }   | ||||
|     return result; | ||||
|   } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user