mirror of
https://github.com/Drop-OSS/drop.git
synced 2025-11-14 00:31:25 +10:00
store certs in db
This commit is contained in:
@ -1,6 +1,7 @@
|
||||
import path from "path";
|
||||
import fs from "fs";
|
||||
import { CertificateBundle } from "./ca";
|
||||
import prisma from "../db/database";
|
||||
|
||||
export type CertificateStore = {
|
||||
store(name: string, data: CertificateBundle): Promise<void>;
|
||||
@ -33,3 +34,63 @@ export const fsCertificateStore = (base: string) => {
|
||||
};
|
||||
return store;
|
||||
};
|
||||
|
||||
export const dbCertificateStore = () => {
|
||||
const store: CertificateStore = {
|
||||
async store(name: string, data: CertificateBundle) {
|
||||
await prisma.certificate.upsert({
|
||||
where: {
|
||||
id: name,
|
||||
},
|
||||
create: {
|
||||
id: name,
|
||||
privateKey: data.priv,
|
||||
certificate: data.cert,
|
||||
},
|
||||
update: {
|
||||
privateKey: data.priv,
|
||||
certificate: data.cert,
|
||||
},
|
||||
});
|
||||
},
|
||||
async fetch(name: string) {
|
||||
const result = await prisma.certificate.findUnique({
|
||||
where: {
|
||||
id: name,
|
||||
},
|
||||
select: {
|
||||
privateKey: true,
|
||||
certificate: true,
|
||||
},
|
||||
});
|
||||
if (result === null) return undefined;
|
||||
return {
|
||||
priv: result.privateKey,
|
||||
cert: result.certificate,
|
||||
};
|
||||
},
|
||||
async blacklistCertificate(name: string) {
|
||||
await prisma.certificate.update({
|
||||
where: {
|
||||
id: name,
|
||||
},
|
||||
data: {
|
||||
blacklisted: true,
|
||||
},
|
||||
});
|
||||
},
|
||||
async checkBlacklistCertificate(name: string): Promise<boolean> {
|
||||
const result = await prisma.certificate.findUnique({
|
||||
where: {
|
||||
id: name,
|
||||
},
|
||||
select: {
|
||||
blacklisted: true,
|
||||
},
|
||||
});
|
||||
if (result === null) return false;
|
||||
return result.blacklisted;
|
||||
},
|
||||
};
|
||||
return store;
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user