ToolJet/server/data-migrations/1683022868045-environmentDataSourceMappingFix.ts

86 lines
3.4 KiB
TypeScript
Raw Normal View History

2025-02-25 06:52:50 +00:00
import { DataSourceOptions } from '@entities/data_source_options.entity';
import { Organization } from '@entities/organization.entity';
import { MigrationInterface, QueryRunner } from 'typeorm';
import { NestFactory } from '@nestjs/core';
import { AppModule } from '@modules/app/module';
import { filterEncryptedFromOptions } from '@helpers/migration.helper';
import { TOOLJET_EDITIONS, getImportPath } from '@modules/app/constants';
import { getTooljetEdition } from '@helpers/utils.helper';
2025-02-25 06:52:50 +00:00
export class environmentDataSourceMappingFix1683022868045 implements MigrationInterface {
// This is to fix apps having only single environment option values (Imported from CE)
public async up(queryRunner: QueryRunner): Promise<void> {
const edition: TOOLJET_EDITIONS = getTooljetEdition() as TOOLJET_EDITIONS;
2025-08-03 07:09:18 +00:00
if (edition !== TOOLJET_EDITIONS.EE) {
console.log('Skipping migration as it is not EE edition');
return;
}
2025-02-25 06:52:50 +00:00
const entityManager = queryRunner.manager;
const organizations = await entityManager.find(Organization, {
relations: ['appEnvironments'],
});
2025-08-03 07:09:18 +00:00
if (organizations?.length === 0) {
console.log('No organizations found, skipping migration.');
return;
}
const nestApp = await NestFactory.createApplicationContext(await AppModule.register({ IS_GET_CONTEXT: true }));
const { EncryptionService } = await import(`${await getImportPath(true, edition)}/encryption/service`);
const encryptionService = nestApp.get(EncryptionService);
2025-02-25 06:52:50 +00:00
for (const organization of organizations) {
const appEnvironments = organization.appEnvironments;
const defaultEnv = appEnvironments.find((e) => e.isDefault).id;
const nonDefaultEnvs = appEnvironments.filter((ae) => !ae.isDefault);
const defaultEnvOption = await entityManager.find(DataSourceOptions, {
where: { environmentId: defaultEnv },
});
if (defaultEnvOption?.length) {
for (const nonDefaultEnv of nonDefaultEnvs) {
const envOptionCount = await entityManager.count(DataSourceOptions, {
where: { environmentId: nonDefaultEnv.id },
});
if (defaultEnvOption?.length !== envOptionCount) {
const envOption = await entityManager.find(DataSourceOptions, {
where: { environmentId: nonDefaultEnv.id },
select: ['dataSourceId'],
});
const envOptionDS = envOption.map((options) => options.dataSourceId);
const dataSourcesOptionsToAdd = defaultEnvOption.filter(
(dsOptions) => !envOptionDS?.includes(dsOptions.dataSourceId)
);
for (const dataSourcesOptionToAdd of dataSourcesOptionsToAdd) {
//copy the options and remove secrets, then create new one for new environments
const newOptions = await filterEncryptedFromOptions(
dataSourcesOptionToAdd.options,
encryptionService,
null,
false,
entityManager
);
await entityManager.save(
entityManager.create(DataSourceOptions, {
environmentId: nonDefaultEnv.id,
options: newOptions,
dataSourceId: dataSourcesOptionToAdd.dataSourceId,
})
);
}
}
}
}
}
await nestApp.close();
}
public async down(queryRunner: QueryRunner): Promise<void> {}
}