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>
59 lines
2.2 KiB
TypeScript
59 lines
2.2 KiB
TypeScript
import { getTooljetEdition } from '@helpers/utils.helper';
|
|
import { TOOLJET_EDITIONS } from '@modules/app/constants';
|
|
import { DataBaseConstraints } from 'src/helpers/db_constraints.constants';
|
|
import { MigrationInterface, QueryRunner, TableUnique } from 'typeorm';
|
|
|
|
export class AddUniqueAppSlug1698222463379 implements MigrationInterface {
|
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
|
const edition: TOOLJET_EDITIONS = getTooljetEdition() as TOOLJET_EDITIONS;
|
|
// If edition is not cloud, skip this migration
|
|
if (edition !== TOOLJET_EDITIONS.Cloud) {
|
|
console.log('Migration is only restricted for cloud edition.');
|
|
return; // Exit the migration early
|
|
}
|
|
/* Lets check if the constraint is existed or not.
|
|
Cloud doesn't have the constrain for sure. but this steps only for the developer's machine
|
|
*/
|
|
const query = `
|
|
SELECT conname
|
|
FROM pg_constraint
|
|
WHERE conname = '${DataBaseConstraints.APP_SLUG_UNIQUE}';
|
|
`;
|
|
const result = await queryRunner.query(query);
|
|
|
|
if (result && result.length > 0) {
|
|
console.log(`Constraint with name '${DataBaseConstraints.APP_SLUG_UNIQUE}' exists. So skipping the migration`);
|
|
} else {
|
|
console.log(
|
|
`Constraint with name '${DataBaseConstraints.APP_SLUG_UNIQUE}' does not exist. Going to do the data-migration`
|
|
);
|
|
|
|
/* Replacing the identical slugs with the app-id but will keep the first row as it is */
|
|
const dataMigrationQuery = `WITH CTE AS (
|
|
SELECT id, slug,
|
|
ROW_NUMBER() OVER (PARTITION BY slug ORDER BY id) AS rn
|
|
FROM apps
|
|
)
|
|
UPDATE apps AS a
|
|
SET slug = CASE
|
|
WHEN a.slug IS NULL OR TRIM(a.slug) = '' THEN a.id::varchar
|
|
ELSE CASE WHEN cte.rn = 1 THEN a.slug ELSE a.id::varchar END
|
|
END
|
|
FROM CTE cte
|
|
WHERE a.id = cte.id;
|
|
`;
|
|
await queryRunner.query(dataMigrationQuery);
|
|
|
|
/* Adding new constraint */
|
|
await queryRunner.createUniqueConstraint(
|
|
'apps',
|
|
new TableUnique({
|
|
name: DataBaseConstraints.APP_SLUG_UNIQUE,
|
|
columnNames: ['slug'],
|
|
})
|
|
);
|
|
}
|
|
}
|
|
|
|
public async down(queryRunner: QueryRunner): Promise<void> {}
|
|
}
|