* stash * refactor, working in non-collab + collab editor * attachment styling * Avoid crypto require in browser * AttachmentIcon, handling unknown types * Do not allow attachment creation for file sizes over limit * Allow image as file attachment * Upload placeholder styling * lint * Refactor: Do not use placeholder for file attachmentuploads * Add loading spinner * fix: Extra paragraphs around attachments on insert * Bump editor * fix build error * Remove attachment placeholder when upload fails * Remove unused styles * fix: Attachments on shared pages * Merge fixes
84 lines
2.3 KiB
TypeScript
84 lines
2.3 KiB
TypeScript
import { escapeRegExp } from "lodash";
|
|
import { Document } from "@server/models";
|
|
import Attachment from "@server/models/Attachment";
|
|
import parseAttachmentIds from "@server/utils/parseAttachmentIds";
|
|
import { getSignedUrl } from "@server/utils/s3";
|
|
import presentUser from "./user";
|
|
|
|
type Options = {
|
|
isPublic?: boolean;
|
|
};
|
|
|
|
// replaces attachments.redirect urls with signed/authenticated url equivalents
|
|
async function replaceImageAttachments(text: string) {
|
|
const attachmentIds = parseAttachmentIds(text);
|
|
await Promise.all(
|
|
attachmentIds.map(async (id) => {
|
|
const attachment = await Attachment.findByPk(id);
|
|
|
|
if (attachment) {
|
|
const signedUrl = await getSignedUrl(attachment.key, 3600);
|
|
text = text.replace(
|
|
new RegExp(escapeRegExp(attachment.redirectUrl), "g"),
|
|
signedUrl
|
|
);
|
|
}
|
|
})
|
|
);
|
|
|
|
return text;
|
|
}
|
|
|
|
export default async function present(
|
|
document: Document,
|
|
options: Options | null | undefined = {}
|
|
) {
|
|
options = {
|
|
isPublic: false,
|
|
...options,
|
|
};
|
|
await document.migrateVersion();
|
|
const text = options.isPublic
|
|
? await replaceImageAttachments(document.text)
|
|
: document.text;
|
|
|
|
const data: Record<string, any> = {
|
|
id: document.id,
|
|
url: document.url,
|
|
urlId: document.urlId,
|
|
title: document.title,
|
|
text,
|
|
tasks: document.tasks,
|
|
createdAt: document.createdAt,
|
|
createdBy: undefined,
|
|
updatedAt: document.updatedAt,
|
|
updatedBy: undefined,
|
|
publishedAt: document.publishedAt,
|
|
archivedAt: document.archivedAt,
|
|
deletedAt: document.deletedAt,
|
|
teamId: document.teamId,
|
|
template: document.template,
|
|
templateId: document.templateId,
|
|
collaboratorIds: [],
|
|
revision: document.revisionCount,
|
|
fullWidth: document.fullWidth,
|
|
collectionId: undefined,
|
|
parentDocumentId: undefined,
|
|
lastViewedAt: undefined,
|
|
};
|
|
|
|
if (!!document.views && document.views.length > 0) {
|
|
data.lastViewedAt = document.views[0].updatedAt;
|
|
}
|
|
|
|
if (!options.isPublic) {
|
|
data.collectionId = document.collectionId;
|
|
data.parentDocumentId = document.parentDocumentId;
|
|
data.createdBy = presentUser(document.createdBy);
|
|
data.updatedBy = presentUser(document.updatedBy);
|
|
data.collaboratorIds = document.collaboratorIds;
|
|
}
|
|
|
|
return data;
|
|
}
|