updating certifcates utility

This commit is contained in:
2021-09-25 11:56:18 +02:00
parent 4a46751505
commit 26acc020b9
3 changed files with 57 additions and 58 deletions

View File

@@ -4,7 +4,7 @@ import cors from 'cors';
const app = express(); const app = express();
app.set('port', process.env.PORT || 3000); app.set('port', process.env.PORT || 5050);
app.use(cors()); app.use(cors());
app.use(express.json()); app.use(express.json());
app.use(express.urlencoded()); app.use(express.urlencoded());

View File

@@ -7,9 +7,9 @@ export class CertificateDownloader{
private readonly updateApi = '/v1/dgc/signercertificate/update' private readonly updateApi = '/v1/dgc/signercertificate/update'
private readonly statusApi = '/v1/dgc/signercertificate/status' private readonly statusApi = '/v1/dgc/signercertificate/status'
private readonly keyStorage = './cerificate_collection.json'; private readonly keyStorage = './cerificate_collection.json';
// private readonly timeSpan = 86400000; private readonly timeSpan = 86400000;
private readonly timeSpan = 1; // private readonly timeSpan = 1;
private cerficateCollection:unknown = {}; private certificatesCollection:{kid:string,certificate:string}[] = [];
private currentValidKids:string[] = []; private currentValidKids:string[] = [];
public async getCertificates(): Promise<unknown> { public async getCertificates(): Promise<unknown> {
@@ -19,12 +19,12 @@ export class CertificateDownloader{
data = (await file.readFile()).toString('utf-8'); data = (await file.readFile()).toString('utf-8');
await file.close(); await file.close();
const savedData = JSON.parse( data || '{}'); const savedData = JSON.parse( data || '{}');
// if(savedData.lastupdateDate == null || Date.now() - savedData?.lastupdateDate > this.timeSpan){ if(savedData.lastupdateDate == null || Date.now() - savedData?.lastupdateDate > this.timeSpan){
// await this.getAllCertificate(); await this.getAllCertificate();
// } else { } else {
this.cerficateCollection = savedData.certificates; this.certificatesCollection = savedData.certificates;
// } }
return this.cerficateCollection; return this.certificatesCollection;
} catch (error) { } catch (error) {
console.log(error); console.log(error);
if(error.errno == -2){ if(error.errno == -2){
@@ -42,54 +42,52 @@ export class CertificateDownloader{
// return CertificateDownloader.instance; // return CertificateDownloader.instance;
// } // }
async getAllCertificate(): Promise<void> {
this.cerficateCollection = {};
const response:AxiosResponse<JSON> = (await axios.get('https://raw.githubusercontent.com/lovasoa/sanipasse/master/src/assets/Digital_Green_Certificate_Signing_Keys.json'));
if(response.status == 200){
console.log(response.data);
this.cerficateCollection = response.data;
console.log(response);
const lastupdateDate = Date.now();
const file = await fs.open(this.keyStorage,'w');
file.writeFile(JSON.stringify({'certificates':this.cerficateCollection, lastupdateDate}));
console.log(this.cerficateCollection);
await file.close();
}else{
throw new Error(response.statusText);
}
}
// async getAllCertificate(): Promise<void> { // async getAllCertificate(): Promise<void> {
// let exit = false; // this.cerficateCollection = {};
// let headers = {}; // const response:AxiosResponse<JSON> = (await axios.get('https://raw.githubusercontent.com/lovasoa/sanipasse/master/src/assets/Digital_Green_Certificate_Signing_Keys.json'));
// this.cerficateCollection = []; // if(response.status == 200){
// while(!exit){ // console.log(response.data);
// // const response = await fetch(this.baseUrl+this.updateApi,{headers}); // this.cerficateCollection = response.data;
// const response:AxiosResponse = await axios.get(this.baseUrl+this.updateApi,{headers}); // console.log(response);
// // console.log(response.headers);
// headers = {'X-RESUME-TOKEN': response.headers['x-resume-token']};
// const currentKid:string = response.headers['x-kid'];
// if(this.currentValidKids.includes(currentKid)){
// // console.log('=========AGGIUNG===========');
// const cert = `-----BEGIN CERTIFICATE-----${response.data}-----END CERTIFICATE-----`;
// // console.log(cert);
// this.cerficateCollection.push(cert);
// }
// exit = (response.status !== 200);
// }
// const lastupdateDate = Date.now(); // const lastupdateDate = Date.now();
// const file = await fs.open(this.keyStorage,'w'); // const file = await fs.open(this.keyStorage,'w');
// file.writeFile(JSON.stringify({'certificates':this.cerficateCollection, lastupdateDate})); // file.writeFile(JSON.stringify({'certificates':this.cerficateCollection, lastupdateDate}));
// console.log(this.cerficateCollection); // console.log(this.cerficateCollection);
// await file.close(); // await file.close();
// }else{
// throw new Error(response.statusText);
// }
// } // }
// async updateKids(): Promise<void> { async getAllCertificate(): Promise<void> {
// try { let exit = false;
// const resp = await axios.get(this.baseUrl+this.statusApi); let headers = {};
// this.currentValidKids = await resp.data as string[]; this.certificatesCollection = [];
// } catch (error) { while(!exit){
// console.log('could not get keyChild ', error); const response:AxiosResponse = await axios.get(this.baseUrl+this.updateApi,{headers});
// } headers = {'X-RESUME-TOKEN': response.headers['x-resume-token']};
// } const currentKid:string = response.headers['x-kid'];
if(this.currentValidKids.includes(currentKid)){
// console.log('=========AGGIUNG===========');
const cert = {kid:currentKid, certificate: response.data};
// console.log(cert);
this.certificatesCollection.push(cert);
}
exit = (response.status !== 200);
}
const lastupdateDate = Date.now();
const file = await fs.open(this.keyStorage,'w');
file.writeFile(JSON.stringify({'certificates':this.certificatesCollection, lastupdateDate}));
console.log(this.certificatesCollection);
await file.close();
}
async updateKids(): Promise<void> {
try {
const resp = await axios.get(this.baseUrl+this.statusApi);
this.currentValidKids = await resp.data as string[];
} catch (error) {
console.log('could not get keyChild ', error);
}
}
} }

View File

@@ -25,9 +25,10 @@ export default class Verifier {
async checkCertificate(certificate:string): Promise<unknown>{ async checkCertificate(certificate:string): Promise<unknown>{
console.log(certificate); console.log(certificate);
const dcc = await DCC.fromRaw(certificate); const dcc = await DCC.fromRaw(certificate);
console.log(dcc.payload);
let result = await dcc.checkSignatureWithKeysList(await this.certDownloader.getCertificates()); let result = await dcc.checkSignatureWithKeysList(await this.certDownloader.getCertificates());
const vaccineVerifier = new VaccineVerifier(await this.ruleDownloader.getRules()); // const vaccineVerifier = new VaccineVerifier(await this.ruleDownloader.getRules());
result = {signature: result, valid:vaccineVerifier.checkCertifcate(dcc)}; // result = {signature: result, valid:vaccineVerifier.checkCertifcate(dcc)};
console.log(result); console.log(result);
return result; return result;
} }