ToolJet/server/migrations/1714626631309-CreateSampleDataSourceToExistingWorkspace.ts
Midhun G S 90e7c4cab9
Cloud licensing related changes (#13033)
* added all pending cloud migration

* restrict cloud migrations

* added cloud data-migrations

* Added cloud entities

* keep tables across all

* cloud licensing initial changes

* fix

* payments module

* license counts updates

* update

* Added all pending cloud migration to pre-release + Payments module (#13006)

* added all pending cloud migration

* restrict cloud migrations

* added cloud data-migrations

* Added cloud entities

* keep tables across all

* payments module

* license counts updates

* update

* migration fixes

* pass orgId

* movement

* added cloud instance settings

* org id to license terms

* before merge

* dockerfile changes for cloud

* migration fixes

* subscription

* merge main

* posthog-js package

* fix

* selhostcustomer migration timestamp update

* fix

* fixes

* fix

* fix

* Adding cloud dockerfile changes

* migration fix

* fix

* fix

* fix

* fixes

* added migration progress

* fix

* added migration files for cloud

* fix

* added migrations for cloud

* add organizationId for pages controller

* fixes for plugins script

* fix

* final

* added cloud licensing envs

* UI WRAPPER BUG

* fix

* orgId groups fix

* lint check fixes

* Refactor Dockerfiles to use dynamic branch names for builds

* Feature/promote release permission management (#13020)

* migration and entity changes

* removed extra migration

* added default group permissions

* basic ui changes

* added promote and release permissions

* fixed tooltips for promote and release buttons

* fix

* fixed app promote ability check

* ce compatibility ui change

* ui fixes

* removed console.log

* removed comments

* updated ee-preview.Dockerile

* using base img node:22.15.1-bullseye

* fix for ce render

* Update ce-preview.Dockerfile

* Update ee-preview.Dockerfile

* ui fix

* fix

* fixes

* fixes

* fixes

* fixes

* minor fixes

* fix

---------

Co-authored-by: Souvik <psouvik260@gmail.com>
Co-authored-by: Adish M <44204658+adishM98@users.noreply.github.com>

* Bugfix/git sync pre release (#13098)

* bugfixes

* ui fixes for disabled states in version creation

* minor fixes

* removed unused imports

* fixes

* removed comments

* module file fixes

* module fixes

* white-labelling fixes

* login-configs

* fix for migration for ce

* Fix for app count guard (#13131)

* fix for app count guard

* added check

* for debug

* license key

* Modules : Platform Functionality  (#12994)

* init

* mod

* app import-export

* licensing and UI

* review and permissions

* update

* updates

* update

* update

* fix breadcrumb

* fix app builder error

* remove launch button for modules

* fixed homepage

* fix permission check

---------

Co-authored-by: platform-ops123 <platformops545@gmail.com>
Co-authored-by: gsmithun4 <gsmithun4@gmail.com>

* reverted logs

* tjdb guard and dark mode (#13137)

* ui fixes

* added modules module

* removed unused imports

* fix

* fix

* Cypress fix

* fixes for cloud instance level licensing (#13146)

---------

Co-authored-by: platform-ops123 <platformops545@gmail.com>
Co-authored-by: Rudra deep Biswas <rudra21ultra@gmail.com>
Co-authored-by: Adish M <adish.madhu@gmail.com>
Co-authored-by: Rudhra Deep Biswas <98055396+rudeUltra@users.noreply.github.com>
Co-authored-by: Vijaykant Yadav <vjy239@gmail.com>
Co-authored-by: Rohan Lahori <64496391+rohanlahori@users.noreply.github.com>
Co-authored-by: Souvik <psouvik260@gmail.com>
Co-authored-by: Adish M <44204658+adishM98@users.noreply.github.com>
Co-authored-by: rohanlahori <rohanlahori99@gmail.com>
Co-authored-by: ajith-k-v <ajith.jaban@gmail.com>
2025-07-02 10:57:36 +05:30

119 lines
4.3 KiB
TypeScript

import { Organization } from '@entities/organization.entity';
import { EntityManager, MigrationInterface, QueryRunner } from 'typeorm';
import { NestFactory } from '@nestjs/core/nest-factory';
import { filePathForEnvVars } from '../scripts/database-config-utils';
import { AppEnvironment } from '@entities/app_environments.entity';
import { DataSource } from '@entities/data_source.entity';
import * as fs from 'fs';
import * as dotenv from 'dotenv';
import { AppModule } from '@modules/app/module';
import { DataSourceScopes, DataSourceTypes } from '@modules/data-sources/constants';
import { TOOLJET_EDITIONS, getImportPath } from '@modules/app/constants';
import { IDataSourcesUtilService } from '@modules/data-sources/interfaces/IUtilService';
import { getTooljetEdition } from '@helpers/utils.helper';
export class CreateSampleDataSourceToExistingWorkspace1714626631309 implements MigrationInterface {
public async up(queryRunner: QueryRunner): Promise<void> {
const manager = queryRunner.manager;
const organizationsCount = await manager.count(Organization);
if (organizationsCount === 0) {
console.log('No organizations found, skipping migration.');
return;
}
const appCtx = await NestFactory.createApplicationContext(await AppModule.register({ IS_GET_CONTEXT: true }));
let data: any = process.env;
const envVarsFilePath = filePathForEnvVars(process.env.NODE_ENV);
if (fs.existsSync(envVarsFilePath)) {
data = { ...data, ...dotenv.parse(fs.readFileSync(envVarsFilePath)) };
}
const edition: TOOLJET_EDITIONS = getTooljetEdition() as TOOLJET_EDITIONS;
console.log('inside', edition);
const { DataSourcesUtilService } = await import(`${await getImportPath(true, edition)}/data-sources/util.service`);
const dataSourceService = appCtx.get(DataSourcesUtilService, { strict: false });
const entityManager = queryRunner.manager;
await this.addSampleDB(entityManager, dataSourceService, data);
await appCtx.close();
}
public async addSampleDB(entityManager: EntityManager, dataSourceService: IDataSourcesUtilService, envVar: any) {
const workspaces = await entityManager.find(Organization, {
select: ['id'],
});
for (const workspace of workspaces) {
const { id: organizationId } = workspace;
const config = {
name: 'Sample data source',
kind: 'postgresql',
type: DataSourceTypes.SAMPLE,
scope: DataSourceScopes.GLOBAL,
organization_id: organizationId,
};
const options = [
{
key: 'host',
value: envVar.PG_HOST,
encrypted: true,
},
{
key: 'port',
value: envVar.PG_PORT,
encrypted: true,
},
{
key: 'database',
value: 'sample_db',
},
{
key: 'username',
value: envVar.PG_USER,
encrypted: true,
},
{
key: 'password',
value: envVar.PG_PASS,
encrypted: true,
},
{
key: 'ssl_enabled',
value: false,
encrypted: true,
},
{ key: 'ssl_certificate', value: 'none', encrypted: false },
];
const insertQueryText = `INSERT INTO "data_sources" (${Object.keys(config).join(', ')}) VALUES (${Object.values(
config
).map((_, index) => `$${index + 1}`)}) RETURNING "id", "type", "scope", "created_at", "updated_at"`;
const insertValues = Object.values(config);
const dataSourceList = await entityManager.query(insertQueryText, insertValues);
const dataSource: DataSource = dataSourceList[0];
const allEnvs: AppEnvironment[] = await entityManager.query(
`
SELECT *
FROM app_environments
WHERE organization_id = $1
AND enabled = true
ORDER BY priority ASC
`,
[organizationId]
);
await Promise.all(
allEnvs?.map(async (env) => {
const parsedOptions = await dataSourceService.parseOptionsForCreate(options);
const insertQuery = `INSERT INTO "data_source_options" ( environment_id , data_source_id, options ) VALUES ( $1 , $2 , $3)`;
const values = [env.id, dataSource.id, parsedOptions];
await entityManager.query(insertQuery, values);
})
);
}
}
public async down(queryRunner: QueryRunner): Promise<void> {}
}