Skip to content

Commit

Permalink
📜 mark todos everywhere we might want to revert the rw transaction ju…
Browse files Browse the repository at this point in the history
…st for images
  • Loading branch information
danyx23 committed Mar 20, 2024
1 parent 2d52754 commit 5ae75e6
Show file tree
Hide file tree
Showing 22 changed files with 77 additions and 3 deletions.
4 changes: 2 additions & 2 deletions adminSiteServer/adminRouter.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -317,7 +317,7 @@ getPlainRouteWithROTransaction(
return res.send(explorerPage)
}
)

// TODO: this transaction is only RW because somewhere inside it we fetch images
getPlainRouteNonIdempotentWithRWTransaction(
adminRouter,
"/datapage-preview/:id",
Expand All @@ -339,7 +339,7 @@ getPlainRouteNonIdempotentWithRWTransaction(
)
}
)

// TODO: this transaction is only RW because somewhere inside it we fetch images
getPlainRouteNonIdempotentWithRWTransaction(
adminRouter,
"/grapher/:slug",
Expand Down
1 change: 1 addition & 0 deletions adminSiteServer/app.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -126,6 +126,7 @@ export class OwidAdminApp {
// Public preview of a Gdoc document
app.get("/gdocs/:id/preview", async (req, res) => {
try {
// TODO: this transaction is only RW because somewhere inside it we fetch images
await db.knexReadWriteTransaction(async (knex) => {
const gdoc = await getAndLoadGdocById(
knex,
Expand Down
11 changes: 11 additions & 0 deletions adminSiteServer/mockSiteRouter.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,7 @@ const mockSiteRouter = Router()
mockSiteRouter.use(express.urlencoded({ extended: true }))
mockSiteRouter.use(express.json())

// TODO: this transaction is only RW because somewhere inside it we fetch images
getPlainRouteNonIdempotentWithRWTransaction(
mockSiteRouter,
"/sitemap.xml",
Expand All @@ -80,6 +81,7 @@ getPlainRouteNonIdempotentWithRWTransaction(
}
)

// TODO: this transaction is only RW because somewhere inside it we fetch images
getPlainRouteNonIdempotentWithRWTransaction(
mockSiteRouter,
"/atom.xml",
Expand All @@ -90,6 +92,7 @@ getPlainRouteNonIdempotentWithRWTransaction(
}
)

// TODO: this transaction is only RW because somewhere inside it we fetch images
getPlainRouteNonIdempotentWithRWTransaction(
mockSiteRouter,
"/atom-no-topic-pages.xml",
Expand Down Expand Up @@ -190,6 +193,7 @@ mockSiteRouter.get("/collection/custom", async (_, res) => {
return res.send(await renderDynamicCollectionPage())
})

// TODO: this transaction is only RW because somewhere inside it we fetch images
getPlainRouteNonIdempotentWithRWTransaction(
mockSiteRouter,
"/grapher/:slug",
Expand All @@ -206,6 +210,7 @@ getPlainRouteNonIdempotentWithRWTransaction(
}
)

// TODO: this transaction is only RW because somewhere inside it we fetch images
getPlainRouteNonIdempotentWithRWTransaction(
mockSiteRouter,
"/",
Expand All @@ -215,6 +220,7 @@ getPlainRouteNonIdempotentWithRWTransaction(
}
)

// TODO: this transaction is only RW because somewhere inside it we fetch images
getPlainRouteNonIdempotentWithRWTransaction(
mockSiteRouter,
"/donate",
Expand All @@ -225,6 +231,7 @@ mockSiteRouter.get("/thank-you", async (req, res) =>
res.send(await renderThankYouPage())
)

// TODO: this transaction is only RW because somewhere inside it we fetch images
getPlainRouteNonIdempotentWithRWTransaction(
mockSiteRouter,
"/data-insights/:pageNumberOrSlug?",
Expand Down Expand Up @@ -284,6 +291,7 @@ getPlainRouteWithROTransaction(
}
)

// TODO: this transaction is only RW because somewhere inside it we fetch images
getPlainRouteNonIdempotentWithRWTransaction(
mockSiteRouter,
"/datapage-preview/:id",
Expand Down Expand Up @@ -324,6 +332,7 @@ mockSiteRouter.get("/search", async (req, res) =>
res.send(await renderSearchPage())
)

// TODO: this transaction is only RW because somewhere inside it we fetch images
getPlainRouteNonIdempotentWithRWTransaction(
mockSiteRouter,
"/latest",
Expand All @@ -333,6 +342,7 @@ getPlainRouteNonIdempotentWithRWTransaction(
}
)

// TODO: this transaction is only RW because somewhere inside it we fetch images
getPlainRouteNonIdempotentWithRWTransaction(
mockSiteRouter,
"/latest/page/:pageno",
Expand Down Expand Up @@ -443,6 +453,7 @@ getPlainRouteWithROTransaction(
}
)

// TODO: this transaction is only RW because somewhere inside it we fetch images
getPlainRouteNonIdempotentWithRWTransaction(
mockSiteRouter,
"/*",
Expand Down
1 change: 1 addition & 0 deletions baker/DatapageHelpers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,7 @@ export const getDatapageDataV2 = async (
* see https://github.com/owid/owid-grapher/issues/2121#issue-1676097164
*/
export const getDatapageGdoc = async (
// TODO: this transaction is only RW because somewhere inside it we fetch images
knex: KnexReadWriteTransaction,
googleDocEditLinkOrId: string,
isPreviewing: boolean
Expand Down
3 changes: 3 additions & 0 deletions baker/DeployUtils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,8 @@ export const defaultCommitMessage = async (): Promise<string> => {
/**
* Initiate a deploy, without any checks. Throws error on failure.
*/

// TODO: this transaction is only RW because somewhere inside it we fetch images
const triggerBakeAndDeploy = async (
deployMetadata: DeployMetadata,
knex: KnexReadWriteTransaction,
Expand Down Expand Up @@ -157,6 +159,7 @@ let deploying = false
* If there are no changes in the queue, a deploy won't be initiated.
*/
export const deployIfQueueIsNotEmpty = async (
// TODO: this transaction is only RW because somewhere inside it we fetch images
knex: KnexReadWriteTransaction
) => {
if (deploying) return
Expand Down
11 changes: 10 additions & 1 deletion baker/GrapherBaker.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,8 @@ const renderDatapageIfApplicable = async (
*
* Render a datapage if available, otherwise render a grapher page.
*/

// TODO: this transaction is only RW because somewhere inside it we fetch images
export const renderDataPageOrGrapherPage = async (
grapher: GrapherInterface,
knex: db.KnexReadWriteTransaction,
Expand Down Expand Up @@ -133,6 +135,8 @@ export async function renderDataPageV2(
pageGrapher?: GrapherInterface
imageMetadataDictionary?: Record<string, ImageMetadata>
},

// TODO: this transaction is only RW because somewhere inside it we fetch images
knex: db.KnexReadWriteTransaction
) {
const grapherConfigForVariable = await getMergedGrapherConfigForVariable(
Expand Down Expand Up @@ -174,7 +178,7 @@ export async function renderDataPageV2(
)
const imageMetadata: OwidGdocPostInterface["imageMetadata"] = merge(
{},
// imageMetadataDictionary,
imageMetadataDictionary,
...compact(gdocs.map((gdoc) => gdoc?.imageMetadata))
)
const relatedCharts: OwidGdocPostInterface["relatedCharts"] = gdocs.flatMap(
Expand Down Expand Up @@ -317,6 +321,8 @@ export async function renderDataPageV2(
*/
export const renderPreviewDataPageOrGrapherPage = async (
grapher: GrapherInterface,

// TODO: this transaction is only RW because somewhere inside it we fetch images
knex: db.KnexReadWriteTransaction
) => {
const datapage = await renderDatapageIfApplicable(grapher, true, knex)
Expand Down Expand Up @@ -453,6 +459,8 @@ export interface BakeSingleGrapherChartArguments {

export const bakeSingleGrapherChart = async (
args: BakeSingleGrapherChartArguments,

// TODO: this transaction is only RW because somewhere inside it we fetch images
knex: db.KnexReadWriteTransaction
) => {
const grapher: GrapherInterface = JSON.parse(args.config)
Expand All @@ -475,6 +483,7 @@ export const bakeSingleGrapherChart = async (
}

export const bakeAllChangedGrapherPagesVariablesPngSvgAndDeleteRemovedGraphers =
// TODO: this transaction is only RW because somewhere inside it we fetch images
async (bakedSiteDir: string, knex: db.KnexReadWriteTransaction) => {
const chartsToBake: { id: number; config: string; slug: string }[] =
await knexRaw(
Expand Down
14 changes: 14 additions & 0 deletions baker/SiteBaker.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -480,6 +480,8 @@ export class SiteBaker {
}

// Bake all GDoc posts, or a subset of them if slugs are provided

// TODO: this transaction is only RW because somewhere inside it we fetch images
async bakeGDocPosts(knex: db.KnexReadWriteTransaction, slugs?: string[]) {
if (!this.bakeSteps.has("gdocPosts")) return
const publishedGdocs = await GdocPost.getPublishedGdocPosts(knex)
Expand Down Expand Up @@ -544,6 +546,8 @@ export class SiteBaker {
}

// Bake unique individual pages

// TODO: this transaction is only RW because somewhere inside it we fetch images
private async bakeSpecialPages(knex: db.KnexReadWriteTransaction) {
if (!this.bakeSteps.has("specialPages")) return
await this.stageWrite(
Expand Down Expand Up @@ -700,6 +704,7 @@ export class SiteBaker {
}
}

// TODO: this transaction is only RW because somewhere inside it we fetch images
private async bakeDataInsights(knex: db.KnexReadWriteTransaction) {
if (!this.bakeSteps.has("dataInsights")) return
const latestDataInsights = await db.getPublishedDataInsights(knex, 5)
Expand Down Expand Up @@ -768,6 +773,7 @@ export class SiteBaker {
}
}

// TODO: this transaction is only RW because somewhere inside it we fetch images
private async bakeAuthors(knex: db.KnexReadWriteTransaction) {
if (!this.bakeSteps.has("authors")) return

Expand Down Expand Up @@ -855,6 +861,8 @@ export class SiteBaker {
}

// Bake the blog index

// TODO: this transaction is only RW because somewhere inside it we fetch images
private async bakeBlogIndex(knex: db.KnexReadWriteTransaction) {
if (!this.bakeSteps.has("blogIndex")) return
const allPosts = await getBlogIndex(knex)
Expand All @@ -869,6 +877,8 @@ export class SiteBaker {
}

// Bake the RSS feed

// TODO: this transaction is only RW because somewhere inside it we fetch images
private async bakeRSS(knex: db.KnexReadWriteTransaction) {
if (!this.bakeSteps.has("rss")) return
await this.stageWrite(
Expand Down Expand Up @@ -954,6 +964,7 @@ export class SiteBaker {
this.progressBar.tick({ name: "✅ baked redirects" })
}

// TODO: this transaction is only RW because somewhere inside it we fetch images
async bakeWordpressPages(knex: db.KnexReadWriteTransaction) {
await this.bakeRedirects(knex)
await this.bakeEmbeds(knex)
Expand All @@ -964,6 +975,7 @@ export class SiteBaker {
await this.bakePosts(knex)
}

// TODO: this transaction is only RW because somewhere inside it we fetch images
private async _bakeNonWordpressPages(knex: db.KnexReadWriteTransaction) {
if (this.bakeSteps.has("countries")) {
await bakeCountries(this, knex)
Expand All @@ -988,6 +1000,7 @@ export class SiteBaker {
await this.bakeDriveImages(knex)
}

// TODO: this transaction is only RW because somewhere inside it we fetch images
async bakeNonWordpressPages(knex: db.KnexReadWriteTransaction) {
const progressBarTotal = nonWordpressSteps
.map((step) => this.bakeSteps.has(step))
Expand All @@ -1001,6 +1014,7 @@ export class SiteBaker {
await this._bakeNonWordpressPages(knex)
}

// TODO: this transaction is only RW because somewhere inside it we fetch images
async bakeAll(knex: db.KnexReadWriteTransaction) {
// Ensure caches are correctly initialized
this.flushCache()
Expand Down
2 changes: 2 additions & 0 deletions baker/algolia/indexToAlgolia.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -194,6 +194,7 @@ function generateGdocRecords(
return records
}

// TODO: this transaction is only RW because somewhere inside it we fetch images
// Generate records for countries, WP posts (not including posts that have been succeeded by Gdocs equivalents), and Gdocs
const getPagesRecords = async (knex: db.KnexReadWriteTransaction) => {
const pageviews = await getAnalyticsPageviewsByUrlObj(knex)
Expand Down Expand Up @@ -234,6 +235,7 @@ const indexToAlgolia = async () => {
}
const index = client.initIndex(getIndexName(SearchIndexName.Pages))

// TODO: this transaction is only RW because somewhere inside it we fetch images
const records = await db.knexReadWriteTransaction(
getPagesRecords,
db.TransactionCloseMode.Close
Expand Down
1 change: 1 addition & 0 deletions baker/bakeGdocPost.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ void yargs(hideBin(process.argv))
async ({ slug }) => {
const baker = new SiteBaker(BAKED_SITE_DIR, BAKED_BASE_URL)

// TODO: this transaction is only RW because somewhere inside it we fetch images
await db.knexReadWriteTransaction(
(trx) => baker.bakeGDocPosts(trx, [slug]),
db.TransactionCloseMode.Close
Expand Down
1 change: 1 addition & 0 deletions baker/bakeGdocPosts.ts
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ void yargs(hideBin(process.argv))
async ({ slugs }) => {
const baker = new SiteBaker(BAKED_SITE_DIR, BAKED_BASE_URL)

// TODO: this transaction is only RW because somewhere inside it we fetch images
await db.knexReadWriteTransaction(
(trx) => baker.bakeGDocPosts(trx, slugs),
db.TransactionCloseMode.Close
Expand Down
2 changes: 2 additions & 0 deletions baker/buildLocalBake.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ const bakeDomainToFolder = async (
await fs.mkdirp(dir)
const baker = new SiteBaker(dir, baseUrl, bakeSteps)
console.log(`Baking site locally with baseUrl '${baseUrl}' to dir '${dir}'`)

// TODO: this transaction is only RW because somewhere inside it we fetch images
await db.knexReadWriteTransaction(
(trx) => baker.bakeAll(trx),
db.TransactionCloseMode.Close
Expand Down
1 change: 1 addition & 0 deletions baker/runBakeGraphers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import * as db from "../db/db.js"
*/

const main = async (folder: string) => {
// TODO: this transaction is only RW because somewhere inside it we fetch images
return db.knexReadWriteTransaction(
(trx) =>
bakeAllChangedGrapherPagesVariablesPngSvgAndDeleteRemovedGraphers(
Expand Down
7 changes: 7 additions & 0 deletions baker/siteRenderers.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -189,6 +189,7 @@ export function renderDynamicCollectionPage() {
return renderToHtmlPage(<DynamicCollectionPage baseUrl={BAKED_BASE_URL} />)
}

// TODO: this transaction is only RW because somewhere inside it we fetch images
export const renderGdocsPageBySlug = async (
knex: KnexReadWriteTransaction,
slug: string,
Expand Down Expand Up @@ -279,6 +280,7 @@ export const renderPost = async (
)
}

// TODO: this transaction is only RW because somewhere inside it we fetch images
export const renderFrontPage = async (knex: KnexReadWriteTransaction) => {
const gdocHomepageId = await getHomepageId(knex)

Expand All @@ -296,6 +298,7 @@ export const renderFrontPage = async (knex: KnexReadWriteTransaction) => {
}
}

// TODO: this transaction is only RW because somewhere inside it we fetch images
export const renderDonatePage = async (knex: KnexReadWriteTransaction) => {
const faqsGdoc = (await getAndLoadGdocById(
knex,
Expand Down Expand Up @@ -336,6 +339,7 @@ export const renderDataInsightsIndexPage = (
)
}

// TODO: this transaction is only RW because somewhere inside it we fetch images
export const renderBlogByPageNum = async (
pageNum: number,
knex: KnexReadWriteTransaction
Expand Down Expand Up @@ -364,6 +368,7 @@ export const renderSearchPage = () =>
export const renderNotFoundPage = () =>
renderToHtmlPage(<NotFoundPage baseUrl={BAKED_BASE_URL} />)

// TODO: this transaction is only RW because somewhere inside it we fetch images
export async function makeAtomFeed(knex: KnexReadWriteTransaction) {
const posts = (await getBlogIndex(knex)).slice(0, 10)
return makeAtomFeedFromPosts(posts)
Expand All @@ -372,6 +377,8 @@ export async function makeAtomFeed(knex: KnexReadWriteTransaction) {
// We don't want to include topic pages in the atom feed that is being consumed
// by Mailchimp for sending the "immediate update" newsletter. Instead topic
// pages announcements are sent out manually.

// TODO: this transaction is only RW because somewhere inside it we fetch images
export async function makeAtomFeedNoTopicPages(knex: KnexReadWriteTransaction) {
const posts = (await getBlogIndex(knex))
.filter((post: IndexPost) => post.type !== OwidGdocType.TopicPage)
Expand Down
1 change: 1 addition & 0 deletions baker/sitemap.ts
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,7 @@ const explorerToSitemapUrl = (program: ExplorerProgram): SitemapUrl[] => {
}
}

// TODO: this transaction is only RW because somewhere inside it we fetch images
export const makeSitemap = async (
explorerAdminServer: ExplorerAdminServer,
knex: db.KnexReadWriteTransaction
Expand Down
1 change: 1 addition & 0 deletions baker/startDeployQueueServer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ const main = async () => {
setTimeout(deployIfQueueIsNotEmpty, 10 * 1000)
})

// TODO: this transaction is only RW because somewhere inside it we fetch images
await db.knexReadWriteTransaction(
deployIfQueueIsNotEmpty,
db.TransactionCloseMode.Close
Expand Down
Loading

0 comments on commit 5ae75e6

Please sign in to comment.