From 59f3b80c4df38e4bf522b2766b6497ef1167408a Mon Sep 17 00:00:00 2001 From: Daniel Bachler Date: Tue, 6 Aug 2024 20:26:56 +0200 Subject: [PATCH] =?UTF-8?q?=E2=9C=A8=20finish=20cf=20functions=20fetching?= =?UTF-8?q?=20from=20R2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 1 + adminSiteServer/apiRouter.ts | 2 +- devTools/syncGraphersToR2/syncGraphersToR2.ts | 2 +- functions/_common/grapherRenderer.ts | 28 +++++++++---------- functions/grapher/thumbnail/[slug].ts | 8 ------ package.json | 2 +- packages/@ourworldindata/types/src/index.ts | 2 +- wrangler.toml | 1 - 8 files changed, 19 insertions(+), 27 deletions(-) diff --git a/.gitignore b/.gitignore index 388475e6261..526e12ee4b2 100755 --- a/.gitignore +++ b/.gitignore @@ -43,3 +43,4 @@ dist/ .nx/workspace-data .dev.vars **/tsup.config.bundled*.mjs +cfstorage diff --git a/adminSiteServer/apiRouter.ts b/adminSiteServer/apiRouter.ts index 86f6215a9e5..773213bfb70 100644 --- a/adminSiteServer/apiRouter.ts +++ b/adminSiteServer/apiRouter.ts @@ -85,6 +85,7 @@ import { DbInsertUser, FlatTagGraph, DbRawChartConfig, + R2GrapherConfigDirectory, } from "@ourworldindata/types" import { uuidv7 } from "uuidv7" import { @@ -158,7 +159,6 @@ import path from "path" import { deleteGrapherConfigFromR2, deleteGrapherConfigFromR2ByUUID, - R2GrapherConfigDirectory, saveGrapherConfigToR2, saveGrapherConfigToR2ByUUID, getMd5HashBase64, diff --git a/devTools/syncGraphersToR2/syncGraphersToR2.ts b/devTools/syncGraphersToR2/syncGraphersToR2.ts index b7a546b5f39..fbd948329fa 100644 --- a/devTools/syncGraphersToR2/syncGraphersToR2.ts +++ b/devTools/syncGraphersToR2/syncGraphersToR2.ts @@ -23,7 +23,6 @@ import { KnexReadonlyTransaction, knexReadonlyTransaction, } from "../../db/db.js" -import { R2GrapherConfigDirectory } from "../../adminSiteServer/chartConfigR2Helpers.js" import { base64ToBytes, bytesToBase64, @@ -32,6 +31,7 @@ import { excludeUndefined, HexString, hexToBytes, + R2GrapherConfigDirectory, } from "@ourworldindata/utils" import { string } from "ts-pattern/dist/patterns.js" import { chunk, take } from "lodash" diff --git a/functions/_common/grapherRenderer.ts b/functions/_common/grapherRenderer.ts index 7fdf9ed6065..06fa9e853ed 100644 --- a/functions/_common/grapherRenderer.ts +++ b/functions/_common/grapherRenderer.ts @@ -1,8 +1,9 @@ -import { Grapher, GrapherInterface } from "@ourworldindata/grapher" +import { Grapher } from "@ourworldindata/grapher" import { Bounds, - deserializeJSONFromHTML, excludeUndefined, + GrapherInterface, + R2GrapherConfigDirectory, } from "@ourworldindata/utils" import { svg2png, initialize as initializeSvg2Png } from "svg2png-wasm" import { TimeLogger } from "./timeLogger" @@ -16,7 +17,6 @@ import LatoMedium from "../_common/fonts/LatoLatin-Medium.ttf.bin" import LatoBold from "../_common/fonts/LatoLatin-Bold.ttf.bin" import PlayfairSemiBold from "../_common/fonts/PlayfairDisplayLatin-SemiBold.ttf.bin" import { Env } from "../grapher/thumbnail/[slug].js" -import { R2GrapherConfigDirectory } from "@ourworldindata/types" declare global { // eslint-disable-next-line no-var @@ -150,25 +150,21 @@ async function fetchAndRenderGrapherToSvg({ const url = new URL(`/grapher/${slug}`, env.url) const slugOnly = url.pathname.split("/").pop() - console.log("Fetching", url.href) const key = excludeUndefined([ env.GRAPHER_CONFIG_R2_BUCKET_PATH, - R2GrapherConfigDirectory.bySlug, + R2GrapherConfigDirectory.publishedGrapherBySlug, `${slugOnly}.json`, ]).join("/") - console.log("Fetching", key) + // Fetch grapher config + const fetchResponse = await env.r2ChartConfigs.get(key) - console.log("r2", env.r2ChartConfigs) - - // Fetch grapher config and extract it from the HTML - const grapherConfig: GrapherInterface = await env.r2ChartConfigs.get(key) - - if (!grapherConfig) { - throw new Error("Could not find grapher config") + if (!fetchResponse) { + return null } - grapherLogger.log("fetchGrapherConfig") + const grapherConfig: GrapherInterface = await fetchResponse.json() + console.log("grapher interface", grapherConfig) const bounds = new Bounds(0, 0, options.svgWidth, options.svgHeight) const grapher = new Grapher({ @@ -219,6 +215,10 @@ export const fetchAndRenderGrapher = async ( env, }) + if (!svg) { + return new Response("Not found", { status: 404 }) + } + switch (outType) { case "png": return png(await renderSvgToPng(svg, options)) diff --git a/functions/grapher/thumbnail/[slug].ts b/functions/grapher/thumbnail/[slug].ts index 6add785b1b2..5d003bcd876 100644 --- a/functions/grapher/thumbnail/[slug].ts +++ b/functions/grapher/thumbnail/[slug].ts @@ -34,14 +34,6 @@ router export const onRequestGet: PagesFunction = async (ctx) => { const { request, env } = ctx - const test = await (ctx.env as any).r2ChartConfigs.get( - "devs/daniel/grapher/by-slug/life-expectancy.json" - ) - const listed = await (ctx.env as any).r2ChartConfigs.list({ limit: 10 }) - console.log("listed", listed) - console.log("bucket is null", (ctx.env as any).r2ChartConfigs === null) - console.log("has get get", "get" in (ctx.env as any).r2ChartConfigs) - console.log("r2", test) const url = new URL(request.url) const shouldCache = !url.searchParams.has("nocache") diff --git a/package.json b/package.json index 20f8e503d94..7a5c7142f9b 100644 --- a/package.json +++ b/package.json @@ -26,7 +26,7 @@ "revertLastDbMigration": "tsx --tsconfig tsconfig.tsx.json node_modules/typeorm/cli.js migration:revert -d db/dataSource.ts", "startAdminServer": "node --enable-source-maps ./itsJustJavascript/adminSiteServer/app.js", "startAdminDevServer": "tsx watch --ignore '**.mjs' --tsconfig tsconfig.tsx.json adminSiteServer/app.tsx", - "startLocalCloudflareFunctions": "wrangler pages dev", + "startLocalCloudflareFunctions": "wrangler pages dev --local --persist-to ./cfstorage", "startDeployQueueServer": "node --enable-source-maps ./itsJustJavascript/baker/startDeployQueueServer.js", "startLernaWatcher": "lerna watch --scope '@ourworldindata/*' -- lerna run build --scope=\\$LERNA_PACKAGE_NAME --include-dependents", "startTmuxServer": "node_modules/tmex/tmex dev \"yarn startLernaWatcher\" \"yarn startAdminDevServer\" \"yarn startViteServer\"", diff --git a/packages/@ourworldindata/types/src/index.ts b/packages/@ourworldindata/types/src/index.ts index 42cc9443868..019d446f9ec 100644 --- a/packages/@ourworldindata/types/src/index.ts +++ b/packages/@ourworldindata/types/src/index.ts @@ -18,7 +18,7 @@ export { type RawPageview, type UserCountryInformation, type QueryParams, - type R2GrapherConfigDirectory, + R2GrapherConfigDirectory, } from "./domainTypes/Various.js" export { type BreadcrumbItem, type KeyValueProps } from "./domainTypes/Site.js" export { diff --git a/wrangler.toml b/wrangler.toml index 49263f75f47..ab8b57941aa 100644 --- a/wrangler.toml +++ b/wrangler.toml @@ -36,4 +36,3 @@ GRAPHER_CONFIG_R2_BUCKET_PATH = "v1" binding = "r2ChartConfigs" bucket_name = "owid-grapher-configs-staging" -[env.preview.vars]