From 363ccc8b96bc32d83a4a88b1155ac3c1c6ca60ba Mon Sep 17 00:00:00 2001 From: Claas Augner Date: Wed, 16 Nov 2022 20:51:52 +0100 Subject: [PATCH] chore(build,content,server): allow mp3/mp4/ogg/ttf/webm attachments Allows these files to be used in live samples. --- build/index.ts | 8 ++++---- content/{image.ts => file.ts} | 14 +++++++++++++- server/index.ts | 2 +- 3 files changed, 18 insertions(+), 6 deletions(-) rename content/{image.ts => file.ts} (82%) diff --git a/build/index.ts b/build/index.ts index 1cba26a2897d..42319aa320bd 100644 --- a/build/index.ts +++ b/build/index.ts @@ -265,14 +265,14 @@ function makeTOC(doc) { * * @param {Document} document */ -function getAdjacentImages(documentDirectory) { +function getAdjacentFileAttachments(documentDirectory) { const dirents = fs.readdirSync(documentDirectory, { withFileTypes: true }); return dirents .filter((dirent) => { // This needs to match what we do in filecheck/checker.py return ( !dirent.isDirectory() && - /\.(png|jpeg|jpg|gif|svg|webp)$/i.test(dirent.name) + /\.(mp3|mp4|png|jpeg|jpg|gif|ogg|svg|ttf|webm|webp)$/i.test(dirent.name) ); }) .map((dirent) => path.join(documentDirectory, dirent.name)); @@ -501,8 +501,8 @@ export async function buildDocument( // The checkImageReferences() does 2 things. Checks image *references* and // it returns which images it checked. But we'll need to complement any // other images in the folder. - getAdjacentImages(path.dirname(document.fileInfo.path)).forEach((fp) => - fileAttachments.add(fp) + getAdjacentFileAttachments(path.dirname(document.fileInfo.path)).forEach( + (fp) => fileAttachments.add(fp) ); // Check the img tags for possible flaws and possible build-time rewrites diff --git a/content/image.ts b/content/file.ts similarity index 82% rename from content/image.ts rename to content/file.ts index 66bd16e2bfda..f3536a6cc7d1 100644 --- a/content/image.ts +++ b/content/file.ts @@ -9,6 +9,18 @@ import { DEFAULT_LOCALE } from "../libs/constants"; import { ROOTS } from "../libs/env"; import { memoize, slugToFolder } from "./utils"; +function isFileAttachment(filePath: string) { + return isAudio(filePath) || isVideo(filePath) || isImage(filePath); +} + +function isAudio(filePath) { + return /\.(mp3|ogg)$/i.test(filePath); +} + +function isVideo(filePath) { + return /\.(mp4|webm)$/i.test(filePath); +} + function isImage(filePath) { if (fs.statSync(filePath).isDirectory()) { return false; @@ -38,7 +50,7 @@ function urlToFilePath(url) { const find = memoize((relativePath: string) => { return ROOTS.map((root) => path.join(root, relativePath)).find( - (filePath) => fs.existsSync(filePath) && isImage(filePath) + (filePath) => fs.existsSync(filePath) && isFileAttachment(filePath) ); }); diff --git a/server/index.ts b/server/index.ts index 1e276730f23f..0aa07a1c0d89 100644 --- a/server/index.ts +++ b/server/index.ts @@ -224,7 +224,7 @@ app.get("/*", async (req, res, ...args) => { // TODO: Would be nice to have a list of all supported file extensions // in a constants file. - if (/\.(png|webp|gif|jpe?g|svg)$/.test(req.path)) { + if (/\.(gif|jpe?g|mp3|mp4|png|ogg|svg|ttf|webm|webp)$/.test(req.path)) { // Remember, Image.findByURLWithFallback() will return the absolute file path // iff it exists on disk. // Using a "fallback" strategy here so that images embedded in live samples