Files
sign/apps/web/pages/api/documents/[id].ts

97 lines
2.5 KiB
TypeScript
Raw Normal View History

2023-01-20 13:54:20 +01:00
import {
defaultHandler,
defaultResponder,
getUserFromToken,
} from "@documenso/lib/server";
import prisma from "@documenso/prisma";
import { NextApiRequest, NextApiResponse } from "next";
2023-01-23 21:35:33 +01:00
import { Document as PrismaDocument } from "@prisma/client";
2023-02-01 18:32:59 +01:00
import { getDocument } from "@documenso/lib/query";
import { addDigitalSignature } from "@documenso/signing/addDigitalSignature";
2023-01-20 13:54:20 +01:00
async function getHandler(req: NextApiRequest, res: NextApiResponse) {
const { id: documentId } = req.query;
const { token: recipientToken } = req.query;
2023-01-20 13:54:20 +01:00
if (!documentId) {
return res.status(400).send("Missing parameter documentId.");
2023-01-20 13:54:20 +01:00
}
let user = null;
if (recipientToken) {
// Request from signing page without login
const recipient = await prisma.recipient.findFirst({
where: {
token: recipientToken?.toString(),
},
include: {
Document: { include: { User: true } },
},
});
user = recipient?.Document.User;
} else {
// Request from editor with valid user login
user = await getUserFromToken(req, res);
}
if (!user) return res.status(401).end();
2023-02-01 19:15:43 +01:00
const document: PrismaDocument = await getDocument(+documentId, req, res);
2023-01-20 13:54:20 +01:00
if (!document)
res.status(404).end(`No document with id ${documentId} found.`);
2023-01-23 21:25:53 +01:00
const signaturesCount = await prisma.signature.count({
where: {
Field: {
documentId: document.id,
},
},
});
let signedDocumentAsBase64 = document.document;
// No need to add a signature, if no one signed yet.
if (signaturesCount > 0) {
signedDocumentAsBase64 = await addDigitalSignature(document.document);
}
const buffer: Buffer = Buffer.from(signedDocumentAsBase64, "base64");
2023-01-23 21:25:53 +01:00
res.setHeader("Content-Type", "application/pdf");
2023-03-02 17:04:51 +01:00
res.setHeader("Content-Length", buffer.length);
2023-03-01 14:30:49 +01:00
res.setHeader(
"Content-Disposition",
`attachment; filename=${document.title}`
);
2023-01-23 21:25:53 +01:00
2023-03-02 18:42:38 +01:00
return res.status(200).send(buffer);
2023-01-20 13:54:20 +01:00
}
2023-01-24 18:18:26 +01:00
async function deleteHandler(req: NextApiRequest, res: NextApiResponse) {
2023-01-25 12:24:26 +01:00
const user = await getUserFromToken(req, res);
2023-01-24 18:18:26 +01:00
const { id: documentId } = req.query;
if (!user) return;
if (!documentId) {
res.status(400).send("Missing parameter documentId.");
return;
}
await prisma.document
.delete({
where: {
id: +documentId,
},
})
.then(() => {
res.status(200).end();
});
}
2023-01-20 13:54:20 +01:00
export default defaultHandler({
GET: Promise.resolve({ default: defaultResponder(getHandler) }),
2023-01-24 18:18:26 +01:00
DELETE: Promise.resolve({ default: defaultResponder(deleteHandler) }),
2023-01-20 13:54:20 +01:00
});