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>
88 lines
3.3 KiB
TypeScript
88 lines
3.3 KiB
TypeScript
import { getEnvVars } from './database-config-utils';
|
|
import { NestFactory } from '@nestjs/core';
|
|
import { AppModule } from '@modules/app/module';
|
|
import { INestApplicationContext } from '@nestjs/common';
|
|
import { PluginsService } from '@modules/plugins/service';
|
|
import { CreatePluginDto } from '@modules/plugins/dto';
|
|
import * as availablePlugins from 'src/assets/marketplace/plugins.json';
|
|
import { validateSync } from 'class-validator';
|
|
import { EntityManager } from 'typeorm';
|
|
import { Plugin } from 'src/entities/plugin.entity';
|
|
import { getImportPath, TOOLJET_EDITIONS } from '@modules/app/constants';
|
|
import { getTooljetEdition } from '@helpers/utils.helper';
|
|
|
|
const ENV_VARS = getEnvVars();
|
|
|
|
async function bootstrap() {
|
|
const nestApp = await NestFactory.createApplicationContext(await AppModule.register({ IS_GET_CONTEXT: true }), {
|
|
logger: ['error', 'warn'],
|
|
});
|
|
|
|
await validateAndReloadPlugins(nestApp);
|
|
|
|
await nestApp.close();
|
|
process.exit(0);
|
|
}
|
|
|
|
async function validateAndReloadPlugins(nestApp: INestApplicationContext) {
|
|
const edition: TOOLJET_EDITIONS = getTooljetEdition() as TOOLJET_EDITIONS;
|
|
const { PluginsService } = await import(`${await getImportPath(true, edition)}/plugins/service`);
|
|
const pluginsService = nestApp.get(PluginsService);
|
|
const pluginsToReload = fetchPluginsToReload();
|
|
const validPluginDtos: CreatePluginDto[] = [];
|
|
const invalidPluginDtos: CreatePluginDto[] = [];
|
|
|
|
console.log('Plugins to reload:', pluginsToReload);
|
|
|
|
for (const pluginId of pluginsToReload) {
|
|
const pluginDto = Object.assign(new CreatePluginDto(), findPluginDetails(pluginId));
|
|
const validationErrors = validateSync(pluginDto);
|
|
|
|
if (validationErrors.length === 0) {
|
|
validPluginDtos.push(pluginDto);
|
|
} else {
|
|
console.log(`Plugin with ID '${pluginId}' has validation errors:`, validationErrors);
|
|
invalidPluginDtos.push(pluginDto);
|
|
}
|
|
}
|
|
|
|
invalidPluginDtos.length > 0 &&
|
|
console.log(
|
|
'Skipping invalid plugins:',
|
|
invalidPluginDtos.map((dto) => dto.id),
|
|
'\n'
|
|
);
|
|
|
|
for (const dto of validPluginDtos) {
|
|
const entityManager = nestApp.get(EntityManager);
|
|
const plugins = await entityManager.find(Plugin, { where: { pluginId: dto.id } });
|
|
const pluginDbIds = [];
|
|
|
|
// Note: Plugins are installed at instance level. But there is no uniqueness check for the plugin.
|
|
// This means that same plugin can be installed multiple times but this is restricted at UI.
|
|
// Hence when reloading, we are reloading all the plugins installed of the same name.
|
|
// If in future we support installing different versions of the same plugin, we should remove it selectively.
|
|
for (const plugin of plugins) {
|
|
await pluginsService.reload(plugin.id);
|
|
pluginDbIds.push(plugin.id);
|
|
}
|
|
|
|
console.log('Reloaded:', dto.id, pluginDbIds);
|
|
}
|
|
}
|
|
|
|
function findPluginDetails(pluginId: string) {
|
|
return availablePlugins.find((p: { id: string }) => p.id === pluginId);
|
|
}
|
|
|
|
function fetchPluginsToReload(): string[] {
|
|
if (!ENV_VARS.PLUGINS_TO_RELOAD) return [];
|
|
return sanitizeArray(ENV_VARS.PLUGINS_TO_RELOAD);
|
|
}
|
|
|
|
function sanitizeArray(pluginsToReload: string): string[] {
|
|
return [...new Set(pluginsToReload.split(',').map((pluginId: string) => pluginId.trim()))];
|
|
}
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
bootstrap();
|