From 240aa188b9e3422c8bacf92fcc62f7856ff51fa1 Mon Sep 17 00:00:00 2001 From: Marcel Gerber Date: Thu, 28 Mar 2024 00:06:32 +0100 Subject: [PATCH] migrate(entities): drop `$.data.availableEntities` and `$.data` from chart configs --- ...RemoveAvailableEntitiesFromChartConfigs.ts | 40 +++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 db/migration/1711580214803-RemoveAvailableEntitiesFromChartConfigs.ts diff --git a/db/migration/1711580214803-RemoveAvailableEntitiesFromChartConfigs.ts b/db/migration/1711580214803-RemoveAvailableEntitiesFromChartConfigs.ts new file mode 100644 index 00000000000..9e9292c13e6 --- /dev/null +++ b/db/migration/1711580214803-RemoveAvailableEntitiesFromChartConfigs.ts @@ -0,0 +1,40 @@ +import { MigrationInterface, QueryRunner } from "typeorm" + +export class RemoveAvailableEntitiesFromChartConfigs1711580214803 + implements MigrationInterface +{ + // Removes `$.data.availableEntities` from chart configs + // In doing that, we can also remove the whole `$.data` object, because it is not used anymore + public async up(queryRunner: QueryRunner): Promise { + const configColumns = [ + { table: "charts", column: "config" }, + { table: "chart_revisions", column: "config" }, + { table: "suggested_chart_revisions", column: "suggestedConfig" }, + { table: "variables", column: "grapherConfigAdmin" }, + { table: "variables", column: "grapherConfigETL" }, + ] + + for (const { table, column } of configColumns) { + await queryRunner.query( + `-- sql + UPDATE ?? + SET ?? = JSON_REMOVE(??, "$.data") + WHERE JSON_CONTAINS_PATH(??, "one", "$.data") + `, + [table, column, column, column] + ) + + // Update schema version to 004 + await queryRunner.query( + `--sql + UPDATE ?? + SET ?? = JSON_SET(??, "$.$schema", "https://files.ourworldindata.org/schemas/grapher-schema.004.json")`, + [table, column, column] + ) + } + } + + public async down(): Promise { + return + } +}