Skip to content

Commit

Permalink
fix(pdf) Avoid race condition when performing URL resolution for images
Browse files Browse the repository at this point in the history
Signed-off-by: Jerome Simeon <[email protected]>
  • Loading branch information
jeromesimeon committed Sep 21, 2020
1 parent 571a0e4 commit 15b6a10
Showing 1 changed file with 12 additions and 8 deletions.
20 changes: 12 additions & 8 deletions packages/markdown-pdf/src/PdfTransformer.js
Original file line number Diff line number Diff line change
Expand Up @@ -175,7 +175,7 @@ class PdfTransformer {

const printer = new PdfPrinter(fonts);

const placeholderImage = "";
const placeholderImage = '';

// Asynchronously retrieve image as buffer data from URL.
const getRemoteImageData = async (url) => {
Expand All @@ -192,25 +192,29 @@ class PdfTransformer {
}
};

// Walk a JSON object and find any image key starting with 'http' and
// substitute the URL with the image buffer data.
// Walk a JSON object and find any image key starting with 'http' and
// substitute the URL with the image buffer data.
const findReplaceImageUrls = async (object) => {
const updates = [];
await Promise.all(
Object.keys(object).map(async (key) => {
if (Array.isArray(object[key])) {
object[key] = await Promise.all(
await Promise.all(
object[key].map(async (obj) => await findReplaceImageUrls(obj))
);
} else if (typeof object[key] === 'object') {
object[key] = await findReplaceImageUrls(object[key]);
await findReplaceImageUrls(object[key]);
} else {
if (key === 'image' && typeof object[key] === 'string' && object[key].startsWith('http')) {
object[key] = await getRemoteImageData(object[key]);
updates.push({ key: key, content: await getRemoteImageData(object[key]) });
}
}
})
);
return object;
).then(() => {
updates.forEach((update) => {
object[update.key] = update.content;
});
});
};

if(!input.getType) {
Expand Down

0 comments on commit 15b6a10

Please sign in to comment.