32 lines
927 B
JavaScript
32 lines
927 B
JavaScript
export class SeparateHardMuteWordsAndPatterns1706413792769 {
|
|
name = "SeparateHardMuteWordsAndPatterns1706413792769";
|
|
|
|
async up(queryRunner) {
|
|
await queryRunner.query(
|
|
`ALTER TABLE "user_profile" ADD "mutedPatterns" text[] DEFAULT '{}'`,
|
|
);
|
|
await queryRunner.query(`
|
|
UPDATE "user_profile" SET
|
|
"mutedPatterns" = ARRAY(
|
|
SELECT jsonb_array_elements_text(jsonb_path_query_array(
|
|
"mutedWords",
|
|
'$ ? (@.type() == "string")'
|
|
))
|
|
),
|
|
"mutedWords" = jsonb_path_query_array(
|
|
"mutedWords",
|
|
'$ ? (@.type() == "array")'
|
|
)
|
|
`);
|
|
await queryRunner.query(
|
|
`ALTER TABLE "user_profile" ALTER "mutedPatterns" SET NOT NULL`,
|
|
);
|
|
}
|
|
|
|
async down(queryRunner) {
|
|
await queryRunner.query(
|
|
`UPDATE "user_profile" SET "mutedWords" = "mutedWords" || array_to_json("mutedPatterns")::jsonb`,
|
|
);
|
|
await queryRunner.query(`ALTER TABLE "user_profile" DROP "mutedPatterns"`);
|
|
}
|
|
}
|