🐛 Fix escaping workflow name dedup (#1850)

This commit is contained in:
Iván Ovejero
2021-05-31 20:12:55 +02:00
committed by GitHub
parent 8f6344fbd5
commit 65fae11f24
3 changed files with 30 additions and 31 deletions

View File

@@ -12,34 +12,33 @@ export class UniqueWorkflowNames1620824779533 implements MigrationInterface {
tablePrefix = schema + '.' + tablePrefix;
}
const workflowNames = await queryRunner.query(`
SELECT name
FROM ${tablePrefix}workflow_entity
`);
for (const { name } of workflowNames) {
const duplicates = await queryRunner.query(`
const [duplicatesQuery, parameters] = queryRunner.connection.driver.escapeQueryWithParameters(`
SELECT id, name
FROM ${tablePrefix}workflow_entity
WHERE name = '${name}'
WHERE name = :name
ORDER BY "createdAt" ASC
`);
`, { name }, {});
const duplicates = await queryRunner.query(duplicatesQuery, parameters);
if (duplicates.length > 1) {
await Promise.all(duplicates.map(({ id, name }: { id: number; name: string; }, index: number) => {
if (index === 0) return Promise.resolve();
return queryRunner.query(`
const [updateQuery, updateParams] = queryRunner.connection.driver.escapeQueryWithParameters(`
UPDATE ${tablePrefix}workflow_entity
SET name = '${name} ${index + 1}'
SET name = :name
WHERE id = '${id}'
`);
`, { name: `${name} ${index + 1}`}, {});
return queryRunner.query(updateQuery, updateParams);
}));
}
}
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_${tablePrefixPure}a252c527c4c89237221fe2c0ab" ON ${tablePrefix}workflow_entity ("name") `);