mirror of
https://github.com/ToolJet/ToolJet
synced 2026-04-21 21:47:17 +00:00
* 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>
119 lines
4.3 KiB
TypeScript
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> {}
|
|
}
|