1
0
Fork 1
mirror of https://example.com synced 2024-11-23 05:46:39 +09:00
firefish/packages/backend/migration/1644010796173-convert-hard-mutes.js
2023-07-20 04:17:05 +09:00

70 lines
1.7 KiB
JavaScript

import RE2 from "re2";
export class convertHardMutes1644010796173 {
name = "convertHardMutes1644010796173";
async up(queryRunner) {
let entries = await queryRunner.query(
`SELECT "userId", "mutedWords" FROM "user_profile" WHERE "userHost" IS NULL`,
);
for (let i = 0; i < entries.length; i++) {
let words = entries[i].mutedWords
.map((line) => {
if (typeof line === "string") return [];
const regexp = line.join(" ").match(/^\/(.+)\/(.*)$/);
if (regexp) {
// convert regexp's
try {
new RE2(regexp[1], regexp[2]);
return `/${regexp[1]}/${regexp[2]}`;
} catch (err) {
// invalid regex, ignore it
return [];
}
} else {
// remove empty segments
return line.filter((x) => x !== "");
}
})
// remove empty lines
.filter((x) => !(Array.isArray(x) && x.length === 0));
await queryRunner.connection
.createQueryBuilder()
.update("user_profile")
.set({
mutedWords: words,
})
.where("userId = :id", { id: entries[i].userId })
.execute();
}
}
async down(queryRunner) {
let entries = await queryRunner.query(
`SELECT "userId", "mutedWords" FROM "user_profile"`,
);
for (let i = 0; i < entries.length; i++) {
let words = entries[i].mutedWords
.map((line) => {
if (Array.isArray(line)) {
return line;
} else {
// do not split regex at spaces again
return [line];
}
})
// remove empty lines
.filter((x) => !(Array.isArray(x) && x.length === 0));
await queryRunner.connection
.createQueryBuilder()
.update("user_profile")
.set({
mutedWords: words,
})
.where("userId = :id", { id: entries[i].userId })
.execute();
}
}
}