From 754d9d14cd2627fce1a4ddd3fe1f6b9b5dc2b960 Mon Sep 17 00:00:00 2001 From: Devin Ivy Date: Thu, 20 Jun 2024 10:28:31 -0400 Subject: [PATCH] bskyogcard: add cdn tags, tidy --- bskyogcard/src/routes/starter-pack.tsx | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/bskyogcard/src/routes/starter-pack.tsx b/bskyogcard/src/routes/starter-pack.tsx index 9801b0c59e..cb3a553272 100644 --- a/bskyogcard/src/routes/starter-pack.tsx +++ b/bskyogcard/src/routes/starter-pack.tsx @@ -36,25 +36,28 @@ export default function (ctx: AppContext, app: Express) { return res.status(404).end('not found') } const imageEntries = await Promise.all( - starterPack.listItemsSample - .map(li => li.subject) - .concat(starterPack.creator) + [starterPack.creator] + .concat(starterPack.listItemsSample.map(li => li.subject)) // has avatar .filter(p => p.avatar) - // no bad labels + // no sensitive labels .filter(p => !p.labels.some(l => hideAvatarLabels.has(l.val))) .map(async p => { - assert(p.avatar) try { + assert(p.avatar) const image = await getImage(p.avatar) return [p.did, image] as const - } catch (_err) { + } catch (err) { + httpLogger.warn( + {err, uri: uri.toString(), did: p.did}, + 'could not fetch image', + ) return [p.did, null] as const } }), ) const images = new Map( - imageEntries.filter(([_, image]) => image !== null), + imageEntries.filter(([_, image]) => image !== null).slice(0, 7), ) const svg = await satori( , @@ -67,6 +70,7 @@ export default function (ctx: AppContext, app: Express) { const output = await resvg.renderAsync(svg) res.statusCode = 200 res.setHeader('content-type', 'image/png') + res.setHeader('cdn-tag', [...images.keys()].join(',')) return res.end(output.asPng()) }), )